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4 Channel BitScope 


Digital Storage Oscilloscope 
Up to 4 analog channels using industry standard 
probes or POD connected analog inputs. 


Mixed Signal Oscilloscope 
Capture and display up to 4 analog and 8 logic 
channels with sophisticated cross-triggers. 


Spectrum Analyzer 
VA Integrated real-time spectrum analyzer for each 


Logic Analyzer 
PA 8 logic, External Trigger and special purpose 
inputs to capture digital signals down to 25nS. 
Data Recorder 


Record anything DSO can capture. Supports 
live data replay and display export. 


Networking 
Flexible network connectivity supporting 
multi-scope operation, remote monitoring and 
data acquisition. 


Data Export 
Export data with DSO using portable CSV files or 
use libraries to build custom BitScope solutions. 


analog channel with concurrent waveform display. 
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2 Channel BitScope 


Pocket Analyzer 


BitScope DSO Software for Windows and Linux 


BitScope DSO is fast and intuitive multi-channel test and measurement software for your 
PC or notebook. Whether it's a digital scope, spectrum analyzer, mixed signal scope, 
logic analyzer, waveform generator or data recorder, BitScope DSO supports them all. 


Capture deep buffer one-shots or display waveforms live just like an analog scope. 
Comprehensive test instrument integration means you can view the same data in 
different ways simultaneously at the click of a button. 


DSO may even be used stand-alone to share data with colleagues, students or 
customers. Waveforms may be exported as portable image files or live captures replayed 
on other PCs as if a BitScope was locally connected. 


BitScope DSO supports all current BitScope models, auto-configures when it connects 
and can manage multiple BitScopes concurrently. No manual setup is normally required. 
Data export is available for use with third party software tools and BitScope's networked 
data acquisition capabilities are fully supported. 
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www.bitscope.com 


Debug faster, create more. 
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Giel and Mart, two illustrious, long 
standing colleagues ruling Elektor’s 
graphics department have a special 
awareness for electronics stuff that 
catches the eye. For the purpose of 
virtually all photographic imagery 
you can admire in Elektor every 
month, they pull electronics from 
the hands of lab workers and the 
occasional editor to get illustrations 
ready in time. From time to time, 
their cameras get to see what they 
consider highly photogenic stuff. 
All relative of course — after all, 
this is electronics! So, high grades 
every month for shiny things and 
the weird paraphernalia I've a 
habit of hauling up the stairs of 
Elektor House for the purpose of my 
Retronics instalments. 

When the time comes to design yet 
another Elektor front cover, Giel 
and Mart will not hesitate to draw 
photos on the canvas of items not 
easily thought of as belonging 
together in terms of technology. Like 


a Renesas R32C/111 microcontroller 


and a Raytheon JAN6528 valve. 
Personally, | have no preference 

— the micro | consider a black box 
apparently designed to spawn error 
messages until | get the programming 
right; the valve, an impressive 
looking device with far fewer pins, 
more tolerant to my errors, and with 
a much shorter datasheet. 

If a specialist magazine claims to 
cover electronics there is no way 

the publisher or editor can avoid 
considering the delicate balance 
described as the amount of coverage 
given to microcontrollers (and all 
things embedded) on the one hand, 
and analogue, traditional technology 
on the other. Strong predilections and 
prejudice should be avoided though, 
as well as false reasoning like “no 
computer stuff on a sailboat”. Marine 
Weather Data with the SDR on page 
44 proves the point. 

Although this March 2009 edition 
was announced in Elektor’s 
publishing plan as a ‘microcontroller 
issue’ a long time ago, and it cannot 
be denied that these wonderful 
devices rock the electronics boat, 
we've done our best to respect the 
balance by including articles that 
are hard to associate with bits, bytes 
and number crunching: T-Reg, a 
high-tension regulated power supply, 
Hyper Flea Market on component 
sourcing in China, Design Tips and 
Retronics. A pity there’s so little 
space on the front cover. 


Jan Buiting 
Editor 


IEC KLOr 


electronics worldwide 





The Elektor SDR receiver requires some 
enhancements to the basic design to 
accommodate the special operating 
modes of marine weather data 
broadcasts. In addition to the tuning and 
demodulation software, you need specific 
weather data decoding software and a 
second sound card. Here’s how. 











CONTI 





its Relatives 


Elektor’s famous ‘Tom Thumb’ R8C has just gained a talented sibling. 
The R32C/111, his mathematically gifted big brother, is blessed with 
32-bit architecture, Floating Point Unit arithmetic and a 50 MHz clock 


rate. The R8C and the R32C are both from Renesas’ M16C family, ma- 
king the upgrade to the more versatile 32-bit system extremely simple. 











Here we describe a novel 
design for a high-voltage 
regulator that is very 
simple yet offers excellent 
performance. The output | 
voltage is fully adjustable 

with a single resistor 

without any changes in 
performance. You can use 
several types of valves or 
MOSFETs for the pass device 


in the circuit. 


Although heritage parallel 
or serial ports see declining 
use in practice, to designers, 
a portless PC is a nuisance. 
To solve at least a part of 
the problem, we present an 
interface for the I2C bus 

for connection to an USB 
connection on your PC. It 
works a treat when used in 
the LabVIEW environment. 
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elektor international media 


Elektor International Media provides a multimedia and interactive platform for everyone interested in electronics. 
From professionals passionate about their work to enthusiasts with professional ambitions. 
From beginner to diehard, from student to lecturer. Information, education, inspiration and entertainment. 
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Visit China with Elektor 


(= ve nts 





E combine electronics 


and culture 







Elektor’s third Study Trip to China is planned for 
3—11 April 2009. And you can join us! Check 


your diary today and visit the Elektor website for 





During this 9-day trip we will visit the China 





Electronics Fair in Shenzhen, a professional 






industrial electronics fair with an area of no 






less than 60,000 m2. We will also pay at 






least one visit to the well-known ‘electronics 






more detailed information. 






high street’ in Shanghai. As the name 






suggests, this street is entirely dedicated to 






electronics shops, each vying to be the 






largest. In addition, a variety of interesting 






company visits are on the itinerary (with a 






tour of the production department). We are 






also organising a business conference 






where you can obtain a wealth of infor- 






mation about doing business (and how not 






to do business) in China. Naturally, there’s 





also time for culture. We will visit the Bund, 


French Confession and the Shanghai TV 







tower. There’s also a Shanghai sightseeing 





tour planned. 
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More info, programme and registration at 
www.elektor.com/china-trip 


Email: subscriptions@elektor.com 
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WOVEN MAILBOX 


LED Blinker and Rigol scopes 


Dear Editor — | have two comments | would like to make on 
published articles. 


‘LED Blinker’ by Thomas Scarborough represents an excel- 
lent idea. One can use a 555 if only two LEDs are used. 
Some 555s can also drive up to 200 mA on pin 3. The 
circuit shown here can be used. 





Resistors R2 and R3 can be left out, probably with the 
effect of significantly reducing the life expectancy of 

the LEDs. Well in most cases this will not be a problem 
because the hobby planes do not fly that often and losing 
the LED would not have any significant effect except with 
extremely high light outputs. R2 and R3 can be combined 
depending on the LED’s used. | have also tested it with one 
white and one red LED. 


Regarding the cheap scopes on review in the October 
2007 issue | share some of the frustrations of the author. The 
illustration shows an idea to use the Rigol scopes on the USB 
port without disconnecting the USB cable. 


1. Refresh to display signal captured 
2. Must press disconnect 





ye Ultrascope 


F 2 “(al AR efresh 
K Refresh- H 
I CH1 1 


3. Do adjustment on the scope 
4. Reconnect 
5. Refresh again 


My scope is the Rigol DS 5202CA (200 MHz 1 GS/s), not 
the fancy model with the digital analyzer but | had to buy it 
for further studies. In South Africa, even these Rigol scopes 
are very expensive for private use. This scope was nearly 
worth my month’s full salary, | had to dig into my savings to 
buy it. 


Paul Badenhorst (South Africa) 


Help with Delphi code (2) 
Dear Editor — | just received 
the January 2009 issue and 

| saw Ceri Clatworthy’s mes- 
sage about HID Delphi code in 
‘Mailbox’. 

| am also electronic engineer 
and programmer working with 
C++ Builder, the ‘brother’ of 
Delphi in RAD development. 
For HID access handling | 

am using ‘JvHidDeviceCon- 
troller from Project JEDI and 

it served me well since now 
even though | didn’t get too far 
with it. 


By the way, I’m a contributing 
author to the C++ Builder 
Developers Journal (www. 
bcbjournal.org). 

Please forward my contact info 
to your correspondent if more 
help is needed. 

I’ve been reading Elektor since 
it was first published here in 
Greece and continue to be a 
subscriber. 

George Tokas (Greece) 


Many thanks for responding 
George and we'll happily put 
you through to Ceri. 


Elektor US 

on newsstand distribution 
Hello Editor — your introduc- 
tion to the USA seems to be 
working. | was recently on 
holiday in San Diego and as a 
subscriber to Elektor’s Euro- 
pean edition | was pleased to 
see the US version of Elek- 
tor on the newsstand in the 
Westfield shopping mall in 
UTC (University Town Centre). 
Hopefully this will allow some 
new customers to browse the 
magazine and decide to buy. 
| hope you are successful in 
introducing the people of the 
USA to the great magazine 
that is Elektor. 

Richard Jones (UK) 


Thanks for letting us know 
Richard, our US publisher is wor- 
king hard to gradually expand 
the number of US and Canadian 
bookstores and newsstands stoc- 
king copies of Elektor USA. US 
readers, please let us know your 
findings and requirements. 


Using the PLDM with a 
step-up converter 

Hi Jan — | built this circuit 
(PLDM Power LED Driver 
Module, December 2008, 

Ed.) provisionally using point- 
to-point wiring, and it works 
perfectly. My question is: can 
this design also be used with a 
step-up converter? This option 
may be more attractive, since 
it’s probably more common for 
the input voltage to be too low. 
Hubert Eichler (Germany) 


In principle, the circuit can also 
work with a step-up converter, 
including the types that use a 
2.5-V reference voltage (assu- 
ming that you also use a 2.5-V 
reference IC). However, you must 
ensure that the output voltage 
is always higher than the input 
voltage. With a 12-V supply vol- 
tage, this means always having 
at least five white LEDs connec- 
ted in series across the output, 
and so on. Another thing to bear 
in mind is that the efficiency 
degrades with decreasing input 
voltage for two reasons: 


l. The forward voltages of 
the diodes become more 
significant. 


2. The DC resistance of the coil 
and other losses take a larger 
toll due to the higher current 
levels. 


For these reasons, in my opinion 
a step-down version is prefe- 
rable. It’s always possible to 
choose an appropriate transfor- 
mer voltage. 

Dr Thomas Scherer 


Using a keypad with PIC 
Flowcode 

Dear Elektor people — if you 
are looking for an example 
of how to use a keypad with 
Flowcode, you won't find 
anything useful among the 
examples on the CD or on the 
Matrix Multimedia website. 
The only suggestion you will 
tind for using the getkeypad- 
number macro is to set PBO.2 
high and wait until a ‘portB 
change’ interrupt occurs. This 
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may work in the simulator, but 
it doesn’t work in practice. 


My solution for this is: 


- Set PBO.2 high and con- 
figure PB4.7 as an input, as 
otherwise it cannot detect an 
interrupt. 


- Provide a small wait time 
between configuring the port 
and enabling the interrupt, as 
otherwise an interrupt will be 
triggered immediately. 
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- After the interrupt, PBO.2 must 
be set low again, as otherwise 
the interrupt will continue to be 
triggered as long as a key is 
pressed. 


- After PBO.2 is set high again, 
an interrupt will also be gener- 
ated when a key is released, 
so you should be prepared to 


handle this. 


The Flowcode file I've devel- 
oped shows an example of 
entering a four-digit code. | 
hope that other enthusiasts will 
tind this information useful. 
Ivan Rigaux (Belgium) 


We're sure that a large number 
of Flowcode users will find this 
suggestion very handy. A portion 
of the program is shown here, 
and the complete .fcf file (no. 
081048) is available on the Elek- 
tor website for free download 
(look under the Mailbox heading 
for the March 2009 issue}. 


Electric bicycle 

Dear Jan — | read the ‘e-bike’ 
article in the November 2008 
issue with some interest. | also 
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undertook a similar project 
early last year, and since then 
| have ridden approximately 


1500 km with considerable 


pleasure. 


In the article, you mentioned 
that you used an old mountain 
bike. | would like to point out 
that many bikes nowadays 

are fitted with suspension front 
forks. They make a robust 
impression and even appear 
to be stronger than ‘old-fash- 
ioned’ metal forks. However, 
the fork tubes are made from 
aluminum alloy and are simply 
not suitable for use with an 
electric drive. The aluminum 
wheel mounts will quickly 
become cracked or break 

due to the enormous torque 
generated by the wheel. This 
can lead to very hazardous 
situations. My own bike has an 
aluminum suspension fork, and 
| made a simple metal rein- 
forcement for it that converts it 
into a solid, safe assembly (see 
photo). 

| do not agree with your state- 
ment that ‘the bike behaves 
like normal in all other 
respects’. The maneuverability 
is distinctly reduced by the 


considerable extra weight of 
the front wheel. You get used 
to this fairly quickly, but it 

is certainly not the same as 

a normal bike. Incidentally, 
there are suppliers who have 
no trouble providing various 
wheel sizes, including 27 inch 
(tor example). A rear-wheel 
version is also available. 

It might be a good idea to 
publish one or more follow- 
up articles on topics such as 
selecting a battery, where you 
could examine aspects such as 
weight, dimensions, recharg- 
ing time, price, and so on. 
Based on my experience, the 
controller cuts out with annoy- 
ing abruptness when the bat- 
tery gets low, especially when 
the bike is accelerating. An 
auxiliary circuit that limits the 
‘throttle lever’ in order to pre- 
vent this sort of cut-out would 
be a desirable addition. 
Andre Cramer 

(The Netherlands) 


The author of the article, Thijs 
Beckers, replies: 

Thanks kindly for your message. 
Your remarks about the wheel 
mounts are certainly worth 
mentioning. We also thought it 





would be a good ideal to print a 
photo of your handiwork here. 
What | meant with ‘the bike 
behaves like normal’ is that it 
still ‘operates’ the same way — in 
other words, you don’t have to 
start anything or switch anything 
on or off when you want to go 
for a ride. Naturally, you are 
absolutely right that the hand- 
ling of the bike is different due 
to the different wheel and the 
increased weight. Perhaps |! 
should have worded this more 
clearly in the article. 

In addition, the fact that wheels 
of this sort are also available in 
other sizes should have been 
pointed out. A German col- 
league ordered the wheel for 
us, and he was not sure which 
diameter was most common, so 
he just picked one. 

To be honest, | doubt that there 
will be a follow-up article on 
choosing a battery. This sort of 
information would best be inclu- 
ded directly with the article, but 
this was not possible due to lack 
of space. In addition, writing 
such an article for a specific 
application, such as an elec- 
tric bicycle, would probably be 
regarded as too specialised. It 
would be better to write a gene- 
ral article on the various aspects 
of batteries and their uses. 
However, an article on a circuit 
that limits the throttle might be 
interesting. If you feel the call, 
let us know! 


MailBox Terms 


e Publication of reader's orrespondence 
is at the discretion of the Editor. 

e Viewpoints expressed by 
correspondents are not necessarily 
those of the Editor or Publisher. 

e Correspondence may be 
translated or edited for length, clarity 
and style. 

e When replying to Mailbox 
correspondence, 

please quote Issue number. 

e Please send your MailBox 


correspondence to: 


editor@elektor.com or 

Elektor, The Editor, 

1000 Great West Road, 
Brentford TW8 9HH, England. 
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By Srdjan Tomic 
MikroElektronika - Software Department 


All you need is a PIC18F4520 microcontroller 
and an ENC28J60 serial Ethernet chip. This 
chip is a great solution for other microcontrol- 
ler families as well such as AVR, dsPIC etc. The 
CviLux CJCBA8HF1Y0 RJ-45 connector is used 
for connection to the Ethernet network. An 
LED connected to the microcontroller PORTB. 
pinO simulates a home appliance we want to 
control. 


The mikroC for PIC compiler contains the 
SPI_ Ethernet library that will considerably 
simplify the process of writing a program 
for the microcontroller. By using a few rou- 
tines from this library, it is possible to cre- 
ate the program that will enable electrical 
appliances in your home to be controlled 
via a web browser. 


It is necessary to perform the following op- 
erations within the program: 


Create an html page to run the 
microcontroller through. Import 
it in the code as a string. 


Set IP, DNS, Gateway addresses 


PKG 


D 


Now you need... 





For example, our local network parameters 
are as follows: 


IP : 192.168.20.60 (Control System address) 
DNS: 192.168.20.1 (Domain Name System address) 
GATEWAY : 192.168.20.6 (Gateway address) 
SUBNET : 255.255.255.0 (Subnet mask) 


Disable PORTB analogue inputs. 
The microcontroller pin should be 
cleared and configured as an out- 
put. 


Initialize the SPI module of the 
PIC18F4520 microcontroller. 


Initialize the Serial Ethernet mod- 
ule chip ENC28J60. 


Write the code within the 
Spi_Ethernet_userTCP function 
that will, after receiving command 
via web browser, turn on/off the 
LED connected to the PORTB.pinO. 


Read received data in an endless 
loop. 


ETNERNET 





DEVELOPMENT TOOLS I COMPILERS 





Serial Ethernet module connected to 
EasyPIC5 Development System 


Home automation, home control, 
smart or digital home are just different 
names for comfort, convenience, security and 
power saving. Power saving systems are of increas- 
ing importance nowadays. Even though such systems are 
very expensive, rest assured that they can also be very cheap if 
you make them yourself. There are many ways to control a smart home 
system. One of them is over Ethernet. 


After the web browser “GET” request is re- 
ceived, sent from your computer to the con- 
trol system IP address, the microcontroller 
will respond with a web page stored in its 
memory. This page will then be automati- 
cally displayed on the computer screen by 
the browser. 

When the ON command is received, the 
LED connected to the PORTB.pinO will be 
turned on. 

Likewise, when the OFF command is re- 
ceived the LED will be turned off. If you 
have a relay instead of LED, it is possible to 
control any appliance such as lighting, se- 
curity system, heating system etc. 


The control of any home appliance consists 
of entering control system IP address in the 
web browser and specifying the desired 
commands. 


BOOKS 





The most important part of the program 
is the Spi_Ethernet_userTCP function, 
processing all received commands 


3 i 


Figure 1. MikroElektronika’s Serial Ethernet 
module with ENC28J60 chip 


and Subnet mask obtained from 
your internet provider. 


Advertising article of MikroElektronika www.mikroe.com 
mikroC® is registered trademark by MikroElektronika. All rights reserved. 
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Schematic 1. Connecting the Serial Ethernet module to a PIC18F4520 Example 1: Program to demonstrate control over Ethernet 
| // duplex config flags 
#define Spi_Ethernet_HALFDUPLEX 0x00 // half duplex 
Of course, it is possible to control more than one microcontroller pin, which | #define Spi_Ethernet_FULLDUPLEX 0x01 l full duplex 
j - const char httpHeader[] =“HTTP/1.1 200 OK\nContent-type:“; // HTTP header 
enables you to govern a large number of appliances or complete home auto os char httpMimeTypeHTML 11 E00 EAn Contenttype: A AT Made ype 
mation system as well. const char httpMimeTypeScript[] =“text/plain\n\n”; // TEXT MIME type 
// default html page 
z ma i char indexPagel] = 
fee ee F irha =) The screendump illustrates ‘shtml><head><title>mikroElektronika</title></head><body>\ | 
i 3 = e <n3 align=center>Mikrotlektronika Home Automatization System< > 
foe ala Me nl the web page displayed by | Zformaame=\"input\"action=\"\"method=\"get\">\ 
ġe + £ ST mp id a a iy = iD i the web browser after en- <table align=center width=200 bgcolor=#4974E2 border=2><tr>\ 


Seg ne erate el ain oe Ona 
an E ae ie te ee ee ee i </td></tr><tr><td align=center bgcolor= ><input name=\"tst1\" width= 
a ee ‘ - tering the control system IP type=\"submit\" value- ONV ></t ><td align=center bgcolor-#FFFFOO>\ 


i : : - . <input name=\"tst2\" type=\submit\” value=\"OFF\"></td></tr></table>\ 
ABest Heme duriematirsiien Yrm address. In our example, ON Sane nea han 
and OFF button clicks cause 
// network parameters 
the LED to be turned on char myMacAddr[6] = {0x00, 0x14, 0xA5, 0x76, 0x19, Ox3f}; // my MAC address 
; i char mylpAddr[4] = {192, 168, 20, 60}; // my IP address 
and off, thus simulating the char gwlpAddr[4] ={192, 168, 20, 6}: poe address 
char dnslpAddr[4] = {192, 168, 20, 1}: // dns IP address 


heating control system. char ipMask[4] ={255, 255, 255, O}; // subnet mask 
// end network parameters 





unsigned char getRequest[20]; // HTTP request buffer 


i i : i i ; i unsigned int SPI_Ethernet_UserTCP( char *remoteHost, unsigned int remotePort, 
Below is a list of ready to use functions contained in the SP/ Ethernet Library.This g nsigned int localPork unciqnedintreakenatt) 


. . . . . . { 
library is integrated in mikroC for PIC compiler. unsigned int len; H] my reply length n 
ti= t ; t t t t 
Ere Spi_Ethernet_Init()* marrura | Oeo = 80) retumo pian Agee aie a 
ph deat À : . // get 10 first bytes only of the request, the rest does not matter here 
Spi Read Spi_Ethernet_Enable() Enable network traffic forllen =0; len< 15; len++) getRequestllen| = SPI_Ethernet_getByte(); 
PI_nea —|| Spi_Ethernet_Disable() Disable network traffic getRequest[len] = 0; 
SPI reer oe Spi_Ethernet_doPacket()* Process received packet if(memcmp(getRequest, “GET /” 5)) return(0); // only GET method 
7 emerge! Spi_Ethernet_putByte() Store a byte f(tmememp(getRequest +11,0N" 2)) | da we have ON anand 
= = Spi_Eth t_putByt Store bytes FO= 1; set | 
Spi_Ethernet_doPacket r= phi a in nis else wees 
ne Spi_Ethernet_putConstBytes() Store const bytes iimemcmp(getRequest+1 1,“OFF”3)) — // do we have OFF command 
pi_Ethernet_putByte Spi_Ethernet_putString()* Store string PORTB.FO = 0; // clear PORTB bito 
Sl cae Li Spi_Ethernet_putConstString()* Store const string if (PORTB.FO) 
Spi_Ethernet_putString : = { , P , ase 
Spi Ethernet putConstByt Spi_Ethernet_getByte(* Fetch a byte | memcpy(indexPage+340, “#FFFF00', 6); // highlight (yellow) ON 
pl_ _putcLonstbytes Spi_Ethernet_getBytes() Fetch bytes memcpy(indexPage+431, “#4974E2’, 6); // clear OFF 
Spi_Ethernet_putConstStrin = = 
oe = 9 Spi_Ethernet_UserTCP()* TCP handling code else 
Spi_Ethernet_getByte À : { 
Spi_Ethernet_getBytes Spi_Ethernet_UserUDP() UDP handling code mempy{indexPage+ 340, /#497462, 6); Jı clear ON eee 
- — . memcpy(indexPage+431,” " 6); ighlight (yellow 
Spi_Ethernet_UserTCP a a 2 i nner } 
Spi_Et t_get t Gat ess 
Spi_Ethernet_UserUDP iin Peso neces. pia eerie len = SPI_Ethernet_putConstString(httpHeader); // HTTP header 
Spi_Ethernet_getlpAddress Spi_Ethernet_getDnsIpAddress() Get DNS address len += SPI_Ethernet_putConstString(httpMimeTypeHTML); // with HTML MIME type 
— — Spi_Ethernet_getlpMask() Get IP mask len += SPI_Ethernet_putString(indexPage); // HTML page first part 
Pl -geup return len; // return to the library with the number of bytes to transmit 


Spi_Ethernet_getGwlpAddress 


Spi_Ethernet_getDnslpAddress Spi_Ethernet_confNetwork()* Set network parameters 


unsigned int SPI_Ethernet_UserUDP(_ char *remoteHost, unsigned int remotePort, 





Spi_Ethernet_getlpMask Spi_Ethernet_arpResolve() Send an ARP request unsigned int destPort, unsigned int reqLength) 
Spi_Ethernet_confNetwork Spi_Ethernet_sendUDP() Send an UDP packet return 0; // back to the library with the length of the UDP reply 
Spi_Ethernet_arpResolve Spi_Ethernet_dnsResolve() Send an DNS request adman 
Spi_Ethernet_sendUDP Spi_Ethernet_initDHCP() Send an DHCP request 
= ~ Spi Eth t doDHCPL Ti P l ti ADCON1 |= OxOF ; //no analog inputs 
Spi_Ethernet_dnsResolve Beste easeTime() Reece eee Seve CMCON |= 0x07; // turn off comparators 
Spi_Ethernet_initDHCP Spi_Ethernet_renewDHCP() DHCP renewal request PORTBF0 = 0: 
Spi_Ethernet_doDHCPLeaseTime * SPI Ethernet Library functions used in program TRISB.FO = 0; | // set PORTB.BO as output (rele control pin) 
Spi_Ethernet_renewDHCP |] starts ENC28J60 with: reset bit on PORTC.FO, CS bit on PORTC.F1, 
Spi_Graphic LCD Library Other mikroC for PIC functions used in program: | {3 inito: Ry MAC PARTES, AUP AUPICe 
Spi_Glcd_Init BENE oe : 7Mall duplex, CRC + MAC Unicast + MAC Broadcast filtering 
Spi_Glcd_Set_Side |) Spi_Init() Initialize microcontroller SPI module Spi_Ethernet_Init (@PORTC, 0, &PORTC, 1, 
la naw memcpy() Copy microcontroller RAM memory locations myMacAddr, mylpAddr, Spi_Ethernet_FULLDUPLEX) ; | 
| cC i troller RAM locati // dhcp will not be used here, so use preconfigured addresses One 
ai i a E es SPL Ethernet confNetworktipMask, gwipAd r, dnslpAddr); ` 


wee //doforever We 
ore Nola R NUR olma mere eT Kee UCM CEM te | > Fthernet_doPacket(); // process incoming Ethernet packets 
the programs written for dsPIC® and AVR® microcontrollers can be found on our web | } 
site: www.mikroe.com/en/article/ 





NOTE: 





Microchip®, logo and combinations thereof, PIC® and others are registered trademarks or trademarks of Microchip Corporation or its subsidiaries. 
Other terms and product names may be trademarks of others. 
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March 31, April 1 and 2, 2009 


Embedded Systems Conference Silicon Valley 2009 





San Jose, CA - USA 


Elektor USA magazine will be present on the Exhibition floor at Embedded Systems 
Conference in San Jose, CA on March 31, April 1 and 2, 2009. The ESC Conference with 
its renowned sessions spans March 29 through April 3, 2009. 


At booth # 47 you will be able to meet up with Elektor USA representatives Hugo 
Vanhaecke (Publisher), Jan Buiting (Editor) and Peter Wostrel (Advertising). Visitors 
will also be able to see selected Elektor Shop items and recently published projects. 
Subscribers to Elektor USA are expressly invited to the booth to supply feedback on the 
quality and direction of the magazine. 


Come see us at ESC 2009! 


April 3-12, 2009 





Study trip: Visit China with Elektor 


Tour host: Margriet Debeij (with assistance from local guides and 
interpreters). 


Elektor’s third study trip to China is 
planned for 3-12 April 2009. And you 
can join us! During this 10-day trip we 
will visit the China Electronics Fair in 
Shenzhen, a professional industrial 
electronics fair with an area of no 

less than 60,000 m°. We will also pay 
at least one visit to the well-known 
‘electronics high street’ in Shanghai. 
As the name suggests, this street 

is entirely dedicated to electronics 
shops, each vying to be the largest. 

In addition, a variety of interesting 
company visits are on the itinerary 
(with a tour of the production 
department). We are also organising 
a business conference where you 

can obtain a wealth of information 
about doing business (and how not 
to do business) in China. We put all 
the do’s and don'ts in a tidy list for 
you. Naturally, there's also time for 
culture. We will visit the Bund, French 
Confession and the Shanghai TV tower. 
There's also a Shanghai sightseeing 
tour planned. 

As with the first and second ‘Elektor 
goes to China’ tours, this edition will 
again be blogged using the Elektor 
website. 


Further information at www.elektor. 
com/china-trip 





Rabbit: 


new wireless single-board computers 


Rabbit introduced the BL4S100 
and BL4S200, single board com- 
puters (SBCs) that feature either 
Wi-Fi or ZigBee® connectivity, 
a microprocessor, memory and 
abundant I/O that allow easy 
deployment of wireless nodes for 
industrial, commercial and medi- 
cal applications. 


This unique combination of control, 
I/O and connectivity makes it easy 
for engineers to add wireless con- 
nectivity and control to devices like 
vision systems, wireless industrial 
control systems, printing systems, 
automatic meter reading devices, 
industrial ventilation systems and 
HVAC systems. They also allow 
design engineers to easily gather 
and control data from ZigBee 





nodes and uplink the data to a 
server via Ethernet providing an 
easy to deploy ZigBee-to-Ethernet 
gateway. 


The BL4S100 series offers both Zig- 
Bee and Ethernet connectivity and 
provides embedded design engi- 
neers a simple and straightforward 
approach for machine control and 
data acquisition without the burden 
of cables and wiring harnesses. It 
allows design engineers to deploy 
ZigBee nodes at various control 
points and connect those nodes 
wirelessly to the BL4S100 board. 
The BL4S100 SBC can then gather 
and collate the data from the Zig- 
Bee nodes and uplink it fo a server 
via Ethernet. 


Based on the Rabbit® 4000 micro- 
processor, the BL4S100 series fea- 
tures analog inputs, general pur- 
pose I/O, serial ports, and ZigBee 
and 10 Base-T Ethernet connectiv- 
ity to provide design resources 
for commercial and industrial 
applications. 


Digi’s XBee ZB RF mod- 
ules are also compat- 
ible with other manu- 
facturers’ ZigBee PRO 
compliant devices pro- 
viding outstanding node 
choice flexibility. Based 
on the Rabbit 4000 and 
Rabbit 5000 microproc- 
essors, the BL4S200 
series features Wi-Fi, 
ZigBee and Ethernet 


networking options. 

It also includes a broad range of 
configurable I/O resources, I/O 
expansion using Rabbit's RIO chip, 
and multi-channel analog inputs 
and outputs. 


BL4S100 and BL4S200 develop- 
ment kits are available that include 
the essential hardware and soft- 
ware tools necessary, including 
Rabbit's popular Dynamic C inte- 
grated development environment, 
to make embedded development 
easy. 


www.rabbit.com/products / 
SingleBoards / 


(081040-IV) 
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Yes we Can: www.elektor-usa.com 


Elektor USA is progressing well in 
terms of popularity and subscrib- 
ers. Near the time this edition is 
published, the publication will 
have its own website up and run- 
ning at www.elektor-usa.com. 

The magazine is now also avail- 
able from selected bookstores 
allowing ‘folks’ to browse a copy 
before buying. Starting with the 
February 2009 issue, the maga- 
zine is stocked by selected Bor- 
ders and Barnes & Noble book- 
shops in and around mojor cities 


in the USA. This may be followed 


by other bookstore chains. 

Elektor USA joins the successful 
English, Dutch, Spanish, French, 
German, Italian, Portuguese and 
Brazilian editions centrally pro- 
duced by Elektor International 
Media, with websites to match. 
American and Canadian readers 
originally subscribed to the Euro- 
pean Elektor can now subscribe 
on-line using the specially created 
USA landing page, which con- 
tains an offer they will tind hard 
to refuse. 

www.elektor-usa.com 


Parallax Propeller control board 


The Parallax Propeller Control 
Board is a complete solution for 
controlling robotics platforms. This 
is the same control board that ships 
with the QuadRover robot. The 
Propeller Control Board is capa- 
ble of interfacing directly with the 
Parallax GPS Module, the Hitachi 
HM55B Compass Module and the 
Hitachi H48C 3-Axis Accelerome- 
ter. This provides options for track- 
ing position, heading and acceler- 
ation for robotic applications. 

Twelve of the Propeller I/O pins are 
brought out for customer interfacing 
and control applications, 8 are ded- 
icated to servo control and 8 are 


Note: Accessones are sold separately. 


mikroBasic PRO for AVR® 2008 





US $7.95 _ on T 
7.95 


dedicated to N-Channel MOSFET 
outputs, providing high-current driv- 
ers for solenoids or other high-cur- 
rent devices. There is also a mag- 
neto-pickup compatible tachometer 
input which can be used for mea- 
suring the RPM of gasoline engines. 
The power switch allows you to turn 
all power off, only the Propeller on, 
or the Propeller and servos on. 
There is also a reset button for the 
Propeller chip. A socketed 5 MHz 
crystal is included. 

The Propeller Control Board costs 


U$ 195.99 (plus P&P). 


www.parallax.com (item # 28205) 





@ Software 12C Library 
@ Software SPI Library 

@ Software UART Library 
@ Sound Library 


@ UART Library 
@ Button Library 
@ Conversions Library 
® String Library 


library 
@ OneWire Library 
@ Port Expander Library 
@ PS/2 Library 


MikroElektronika from Serbia have 
recently launched a new BASIC 
compiler for AVR® microcontrollers: 


mikroBasic PRO for AVR® 2008. 





The IDE features project-based @ PWM Library @ SPI Library and more ... 

design and supports an impressive @ PWM 16 bit Library @ SPI Ethernet Library 

range of AVR® microcontrollers. @RS-485 Library @ TWI Library Also, the new compiler has plenty 
MikroBasic PRO for AVR® of practical examples and 
2008 offers a set of librar- mcs aniraa neneman Soten comprehensive documenta- 
ies which simplify the ini- f p=. 200.68 @ AAR = Ses ena eam are — tion which allows a quick 
tialization and use of AVR® Ei vee SS ee start in programming AVR®. 


MCU and its modules: 


@ ADC Library 

@ CANSPI Library 

® Compact Flash Library 

@ EEPROM Library 

@ Flash Memory Library 

@ LCD Library 

@ Manchester Code 
Library 

@ Multi Media Card 


3/2009 - elektor 





REFERENCE GUIDE 
for mikroC 








“PUEEEERT ERLE A 


AVR® hardware development 
tools that completely support 
mikroBasic PRO for AVR® 
2008, are also available. A 
fully functional demonstration 
version (hex output is limited 
to 2 k of program words) is 
available on the MikroElek- 
tronika web site. 





www.mikroe.com 
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New XGamestations XGS AVR 8-Bit & XGS PIC 16-bit 


The XGS AVR 8-Bit from 
XGamestation (Nurve Net- 
works) is based on the Atmel 
Mega AVR644 processor and is 
a highly integrated development 
kit for exploring the Mega AVR 
processors in a fun and engag- 
ing way. On the other hand, 
the product is designed to be 
a serious AVR development kit 
for schools, students, engineers 
and anyone interested in learn- 
ing AVR programming. Clocked 
at over 28 MIPS the XGS AVR 
8-Bit is a seriously powerful 8-Bit 
development board! The system 
has the following features: 


@ AVR644 processor with 64 k 
Flash / 4k SRAM running at 
over 28 MIPS! 

@ 3.3/5 V Dual Supplies 

@ VGA 

@ NTSC/PAL with color genera- 
tion helper hardware 

® Micro SD card interface 

® Serial port 

@ ISP and JTAG programming 
ports 

@ PS/2 keyboard/mouse port 
@ Expansion port header export 
ing numerous I/O, power, and 


signal lines for experimentation 

@ 3.3/5 V internally regulated 
supplies 

® Two game controller ports (Nin- 
tendo compatible). 


The XGS AVR 8-Bit kit gives cus- 
tomers a fun way to learn AVR 
programming in the context of 
graphics, audio, and simple game 
development. So instead of blink- 
ing LEDs and displaying digits 
on a 7-segment display, custom- 
ers will develop graphics appli- 
cations that control the VGA and 
NTSC screen to learn AVR C and 
ASM. The kit is extremely competi- 
tive and comes with the following 
items in the bundle: 


Tiny Multipoint RF modules 


Saelig’s EmbedkF Integrated is a 
new RF solution for economically 
and rapidly adding low power 
wireless capabilities to your own 
analog or digital product, without 
requiring any network license fees 
or complex RF skills. Based on the 
proven EmbedRF board, EmbedRF 
Integrated consists of the EmbedRF 
Baseband Processor, a low cost 
Microchip PIC microcontroller pre- 
loaded with EmbedRF OS firm- 
ware and carefully designed Ger- 
ber design files for integrating an 


RF design directly into your own 
board. 


The EmbedRF Baseband Processor 
with EmbedRF OS firmware han- 
dles the RF data transfer between 
two modules (base-slave or peer-to- 
peer). It has an intelligent search- 
and-link feature which enables a 
given EmbedRF module to initiate 
contact with only the EmbedRF chip 
in closest proximity. The EmbedRF 
OS was designed with power con- 


servation in mind so that a single 
module can run for years off of a 
single Lithium coin cell. EmbedRF 
Integrated can be easily config- 
ured as a periodic transceiver for 
applications such as parameter or 





@ 350+ page printed manual cov- 
ering hardware, software, and 
numerous programming tutorials 
@ AVR ISP MK II programmer + 
USB cable 

@ 9V power supply 

@ A/V cable 

® Game controller 

@ DB9 PC serial port to XGS 
header converter 

@ DVD-ROM with numerous exam- 
ples and complete driver library 
including; Graphics, Sound, Key- 
board, SD card, Serial Comms, 
Mechatronics, and lots more 

- Bonus materials on DVD-ROM 
include electronic copies of 
numerous game development and 


medical data- logging, or an on- 
demand transceiver for remote 
control applications. With 4 ana- 
log inputs, the EmbedRF Integrated 
design can directly interface with 
voltage-output sensors and trans- 


>) EmbedRF LLC 
Rev 2.0 
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electronics gaming hardware 
books 

The XGS AVR 8-Bit is priced at 
$139.99. 


The XGS PIC 16-Bit is 
based on Microchip’s new 16- 
bit PIC24 processor and is a 
highly integrated development 
kit for exploring Microchip's 
16-Bit microcontrollers in a fun 
and engaging way. On the 
other hand, the XGS PIC 16- 
bit is designed to be a serious 
PIC24 16-bBit development kit 
for schools, students, engineers 
and anyone interested in learn- 
ing PIC programming. The sys- 
tem has same features as the 
XGS AVR 8-Bit except a PIC24 
16-bit next generation processor 
with 256 k Flash / 16 k SRAM 
running at over 40 MIPS! 

The kit has the same contents 
as the XGS AVR 8-Bit, except a 
Pickit2 programmer + USB cable 
is supplied. 

The XGS PIC 16-Bit is priced at 
ee 


www.xgamestation.com 


mit the information up to 50 feet 
(15 m). 

Operating with an output power 
up to 5 dBm at frequencies from 
400 MHz to 928 MHz, EmbedRF 
Integrated features intelligent 
search and sophisticated 24-bit 
security capabilities. EmbedRF Inte- 
grated can work on 2.0 to 3.6 V 
trom -40 degC to 85 degC with- 
out trimming. EmbedkF Integrated 
will operate in point-to-point one- 
way, two-way, or two-way multi- 
point star-connection. 


Designing the EmbedRF Integrated 
wireless solution into your product 
costs under $8.00 per unit in quan- 
tity, including the Microchip con- 
troller, free EmbedRF software and 
APls. Designed and made in the 
USA, the EmbedRF Development 
Kit is available now at $ 299, 
with individual modules priced at 


$ 59. 


www.sdelig.com 
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Low Cost ZX Microcontroller 


Elba Corporation have 
started shipping the new- 
est member of the power- 
ful multi-tasking ZX micro- 
controller family intended 
for use by scientists, engi- 
neers, experimenters, hob- 
byists and other embedded 
systems developers. The 
new device, designated 
ZX-328n, is provided in a standard 28-pin 
(300 mil) DIP package. A few additional 
components (e.g. crystal, serial level con- 
verter) are required for device operation. All 
ZX-series microcontrollers are programmed in 
ZBasic, a subset of Microsoft’s Visual Basic 
(VB6) with microcontroller-specific extensions 
and other productivity enhancements. 


The ZX-328n is the newest member of a 
series of ZX devices that operate in ‘native’ 
mode, meaning that the user’s ZBasic pro- 
gram is compiled to native machine code 
for the underlying microcontroller, in this 


case the Atmel ATmega328P MCU. This is in 





contrast to other ZX family 
members that use the ‘vir- 
tual machine’ model (also 
known as the interpreter 
model). 

The new ZX-328n is largely 
source code compatible 
with the previously released 
ZX family members. The ZX- 
328n is intended for entry- 
level users and for simpler applications that 
can be implemented in the available 30 k of 
code space, 2 k of RAM and requiring 16 
I/O lines or fewer. The single unit pricing 
of the ZX-328n is $ 9.95. Volume pricing is 
available. 

Programs for the ZX-328n may be edited, 
compiled and downloaded using a state-of- 
the-art Integrated Development Environment. 
The ZBasic IDE provides productivity-enhanc- 
ing features such as word completion, call 
tips, auto-indenting, syntax highlighting and 
undo/redo. 


www.zbasic.net 


Microchip: stand-alone serial SRAM devices 


Microchip announces a family of 8- and 
32-kByte stand-alone serial SRAM devices 
designed to increase a system’s available 
RAM through adding small, inexpensive 
external devices. The 23A640, 23K640 
(23x640), 234256 and 23K256 [23x256] 
devices fea- 
ture a familiar, 
industry stan- 
dard SPI inter- 
face, provid- 
ing increased 
design flexibil- 
ity while reduc- 
ing design and 
production 
costs. 


Many embed- 
ded applica- 
tions require 
volatile RAM 
for temporary 
data storage, 
or for use as a scratchpad, for bulk process- 
ing and for math algorithms. In many cases, 
this RAM is embedded within the microcon- 
troller (MCU). In the past, the most viable 
way to add more RAM was to buy a larger 
MCU, which could add unnecessary feature 
overhead and increase design costs. The only 
alternative was to add large, parallel-access 
RAM devices that use up large numbers of 


I/O pins. 


3/2009 - elektor 





Microchip's serial SRAM devices provide a 
simple, inexpensive way for designers to add 
more RAM to their application while keep- 
ing the same MCU or, as they require fewer 
MCU I/O resources, even using a smaller 
MCU. The serial RAM devices require just 
four I/O pins 
as opposed to 
16 or 24 pins 
for a parallel 
RAM. Addi- 
tionally, the 
devices feature 
a bus speed 
of 20MHz for 
fast access, 
and low oper- 
ating and 
standby cur- 
rents to help 
extend battery 
life. 

The 23A640 
and 23A256 
devices have an operating voltage range 
of 1.7 - 1.95V. The 23K640 and 23K256 
devices have an operating voltage range of 
2.7 - 3.6V. 

These serial SRAM devices are all available 
in 8-pin SOIC, PDIP and TSSOP packages. 


Samples are available today. 


http:/ /sample.microchip.com 
www. nicrochipdirect.com 
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Bluetooth testing software 


Electronic device OEMs use 
protocol analyzers to overcome 
the complexity of incorporating 
Bluetooth technology into exist 
ing products, greatly expanding 
their marketability. 

Facilitating the entry of Blue- 
tooth into the electronic device 
industry is the modern proto- 
col analyzer, now updated to 
effortlessly examine not only 
the wireless interface between 
devices, such as a glucose moni- 
tor and a telephone modem, but 
also the interface between the 
device CPU and the Bluetooth 
chip inside the device. Medical 
device manufacturers can now 
release Bluetooth-enabled prod- 
ucts with confidence that the 
item has been thoroughly tested 
and will perform to spec in the 
clinical environment. 


Freescale: ‘one-stop-shop’ 32-bit industrial 


Attention all fans of the 
Elektor DigiButler project. 


To help developers successfully 
meet their design challenges, Fre- 
escale Semiconductor has intro- 
duced a ‘one-stop-shop” industrial 
connectivity solution that combines 
its most highly integrated 32-bit 
ColdFire® microcontroller (MCU) 


family with a complimentary offer- 






LA 


ing of the Freescale MQX™ real- 
time operating system (RTOS). 

Freescale’s high-performance 
MCF5225x MCU family offers 
the ultimate industrial connec- 
tivity solution with on-chip USB, 
Ethernet, controller area network 
(CAN) and encryption, along with 
Freescale MQX RTOS and asso- 
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With over 40,000 units in use 


ciated tools and software stacks. 
The combined silicon and soft- 
ware solution gives developers 
exceptional design flexibility, con- 
nectivity options and fast time-to- 
market backed by a full-featured, 
scalable RTOS platform valued at 
approximately $95,000 (USD). 

Based on the 32-bit ColdFire V2 
core, the MCF5225x MCUs are 


well-suited for a broad range of 


industrial networking, building/light- 
ing control and medical applications 
that require high performance and 
connectivity options. For factory 
automation systems, the MCF5225x 
MCU’s USB port can be used to 
develop interfaces to standard USB 
barcode scanners, and the embed- 
ded Fast Ethernet controller makes it 





Understanding Bluetooth communication is simplified by using a protocol 
analyzer. The Packet Timeline in Frontline's analyzer provides a 
graphic-based trace that shows high-level information such as data 
throughput and detailed packet-level information. 


worldwide, spanning a wide vari- 


connectivity solution 


easy to control various terminals in 
a networked building. 

By integrating USB device/host/on- 
the-go, Fast Ethernet and CAN on 
the same device, the MCF5225x 
family allows developers to imple- 
ment the optimal connectivity pro- 
tocol for their application require- 
ments, without having to add sep- 
arate communication controllers. 
The MCUs also include extensive 


integrated serial communica- 
tions capabilities, such as a serial 
peripheral interface (SPI), two 
inter-integrated circuit (I2C) buses 
and three universal asynchronous 
receiver transmitters (UARTs). 

The MCF5225x MCUs feature an 
on-chip cryptographic accelerator 
unit and random number genera- 


ety of communication technolo- 
gies, Charlottesville, Virginia- 
based Frontline Test Equipment, 
Inc. is a leading provider of PC- 
based protocol analyzers for 
special-purpose data communi- 
cation networks. 

Unlike protocol analyzers that 
can only store data for later 
evaluation, Frontline’s analyz- 
ers feature real-time displays to 
turther accelerate the debugging 
and verification process. The 
effect of user actions — whether 
‘positive path’ or regressive — 
are observed in real time on the 
screen of the analyzer. The test 
engineer no longer has to rely 
on notes or memory to recon- 
struct what took place when 
attempting to fix any problems. 


www.fte.com 


tor designed to help safeguard valu- 
able data and intellectual property 
during transmissions across indus- 
trial and building control networks. 
The encryption module supports 
DES, 3DES, AES, MD5 and SHA- 
1 algorithms. 

Evaluation and demonstration sys- 
tems for the MCF5225x family are 
available now. The M52259EVB 
evaluation board is a full-fea- 


tured development system avail- 
able at a suggested resale price 
of $299. The cost-effective 
M52259DEMOKIT demonstration 
board is available at a suggested 
resale promotional price of $ 49. 


www.freescale.com/files /pr/coldfire.html 
www.freescale.com/files /pr/mqx.html 
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The Electronic Kit genes Since 1 993 


otor Drivers/Controllers 


ere are just a few of our controller and 
river modules for AC, DC, Unipolar/Bipolar 
tepper motors and servo motors. See 
ebsite for full range and Pdetails. 


Drives any 5-35Vdc 5, 6 or aai 
8-lead unipolar stepper 
motor rated up to 6 Amps. 
Provides speed and direc- ® 
tion control. Operates in stand-alone or PC- 
controlled mode for CNC use. Connect up to 
six 3179 driver boards to a single parallel 
port. Board supply: 9Vdc. PCB: 80x50mm. 
Kit Order Code: 3179KT - £12.95 
Assembled Order Code: AS3179 - £19.95 





Drive any 5-50Vdc, 5 Amp 1-4 
bi-polar stepper motor using f Rit itt 
externally supplied 5V lev- Thi 
els for STEP and DIREC- : 7 te 
TION control. Opto-isolated F Ái 
inputs make it ideal for CNC applications 
using a PC running suitable software. Board 
supply: 8-30Vdc. PCB: 75x85mm. 

Kit Order Code: 3158KT - £17.95 
Assembled Order Code: AS3158 - £27.95 


Controls the speed of 
most common DC 
motors (rated up to 
32Vdc, 10A) in both 
the forward and re- 
verse direction. The 
range of control is from fully OFF to fully ON 
in both directions. The direction and speed 
are controlled using a single potentiometer. 
Screw terminal block for connections. 

Kit Order Code: 3166v2KT - £17.95 
Assembled Order Code: AS3166v2 - £27.95 





Control the speed of 
almost any common 
DC motor rated up to 
100V/7.5A. Pulse width 
modulation output for 
maximum motor torque 





at all speeds. Supply: 5-15Vdc. Box supplied. 
Dimensions (mm): 60Wx100Lx60H. 

Kit Order Code: 3067KT - £13.95 

Assembled Order Code: AS3067 - £21.95 
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Credit tue 
Sales 


Controllers & Loggers 


Here are just a few of the controller and 
data acquisition and control units we have. 
See website for full details. Suitable PSU 
for all units: Order Code PSU445 £8.95 





Computer controlled 8- 
channel relay board. 5A 
mains rated relay outputs. 4 
, isolated digital inputs. Useful 
in a variety of control and 
PW sensing applications. Con- 
trolled via serial port for programming (using 
our new Windows interface, terminal emula- 
tor or batch files). Includes plastic case 
130x100x30mm. Power Supply: 
12Vdc/500mA. 
Kit Order Code: 3108KT - £54.95 
Assembled Order Code: AS3108 - £64.95 








4-channel temperature log- 
ger for serial port. °C or °F. 
Continuously logs up to 4 
separate sensors located 
= 200m+ from board. Wide 
range ot tree software applications for stor- 
ing/using data. PCB just 45x45mm. Powered 
by PC. Includes one DS1820 sensor. 
Kit Order Code: 3145KT - £17.95 
Assembled Order Code: AS3145 - £24.95 
Additional DS1820 Sensors - £3.95 each 





State-of-the-Art. High security. 
4 channels. Momentary or 
latching relay output. Range 
up to 40m. Up to 15 Tx’s can 
be learnt by one Rx (kit in- 
cludes one Tx but more avail- 
able separately). 4 indicator LED ’s. Rx: PCB 
77x85mm, 12Vdc/6mA (standby). Two and 
Ten channel versions also available. 

Kit Order Code: 3180KT - £44.95 
Assembled Order Code: AS3180 - £54.95 


Call your phone num- 
ber using a DTMF 
phone from anywhere 
in the world and re- 
motely turn on/off any 
of the 4 relays as de- 
sired. User settable Security Password, Anti- 
Tamper, Rings to Answer, Auto Hang-up and 
Lockout. Includes plastic case. Not BT ap- 
proved. 130x110x30mm. Power: 12Vdc. 
Kit Order Code: 3140KT - £54.95 
Assembled Order Code: AS3140 - £69.95 














Individually control 12 on- 
board relays with included | 
infrared remote control unit. | 
Toggle or momentary. 15m+ ~~ 
range. 112x122mm. Supply: 12Vdc/0.5A 
Kit Order Code: 3142KT - £47.95 
Assembled Order Code: AS3142 - £59.95 





PIC & ATMEL Programmer 


We have a wide range of low cost PIC and 
ATMEL Programmers. Complete range an 
documentation available from our web site. 


Programmer Accessories: 

40-pin Wide ZIF socket (ZIF40W) £14.95 
18Vdc Power supply (PSU010) £18.95 
Leads: Parallel (LDC136) £3.95 / Serial 
(LDC441) £3.95 / USB (LDC644) £2.95 





=a USB/Serial connection. Header 
cable for ICSP. Free Windows 
XP software. Wide range of 
upported PICs - see website for 
m maa COMplete listing. ZIF Socket/USB 
lead not included. Supply: 16-18Vdc. 

Kit Order Code: 3149EKT - £39.95 
Assembled Order Code: AS3149E - £49.95 







USB PIC programmer for all 
‘Flash’ devices. No external 
power supply making it truly 
portable. Supplied with box and 
Windows Software. ZIF Socket 
and USB lead not included. m 
Assembled Order Code: AS3128 - £44.95 





e “PICALL” will program virtu- 
ally all 8 to 40 pin serial- 

`- mode AND parallel-mode 

= (PIC16C5x family) pro- 

grammed PIC micro control- 

lers. Free fully functional software. Blank chip 

auto detect for super fast bulk programming. 

Parallel port connection. Supply: 16-18Vdc. 

Assembled Order Code: AS3117 - £24.95 





Uses serial port and any 
standard terminal comms 
program. Program/ Read/ 
Verify Code Data, Write 
Fuse/Lock Bits, Erase and 
Blank Check. 4 LED’s display the status. ZIF 
sockets not included. Supply: 16-18Vdc. 
Kit Order Code: 3123KT - £24.95 
Assembled Order Code: AS3123 - £34.95 
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R32C and its Relativ 


From R8C/13 to R32C/111 


Marc Oliver Reinschmidt (Glyn Germany) and Bernd Westhoft (Renesas Technology Europe) 










Our series on the R8C13 ‘Tom Thumb’ was deservedly popular with Elektor readers, 
who will doubtless be pleased to hear this little 16-bit microcontroller has just gained 
a talented sibling. The R32C/111, his mathematically gifted big brother, is blessed with 
32-bit architecture, Floating Point Unit arithmetic and a 50 MHz clock rate. The R&C and 
the R32C are both from Renesas’ M16C family, making the upgrade to the more versatile 
32-bit system extremely simple. 


For years 32-bit microcontrollers have 
proliferated in applications ever more 
numerous. Anyone who was a Serious 


must by now be using a high-end 
machine to keep up with the demands 
of today’s applications. It’s for this rea- 


devotee of these old 8 or 16-bit devices son that Renesas has expanded the 


i. Rich Peripherals, Full Compatibility 


R320/111 | R32C/116 | R32C/117 | 


R3ZC(CISC+#PU) 
R32C/100 
> Full 32-bit CPU 
> Up to 100MHz 
> Single precision FPU 
Si > 64-bit Memory bus 


R326/118 


256K to 512KB Flash J 384K to IMB Flash J 384K to 1MB Flash GADK to IMB Flash | 
40K or GIKB RAM JE 40K to GIKB RAM AE 40K to GIKB RAM A 48K to GIKB RAM J 


= — CAN 


at A MI6G/6NL, 6NN 


M16C/30P LD cree 3IKBRAM J? SIKBRAM ] 


pas 
) 


5K to 12KB RAM 128K or 256KB Flash) 128KB Flash, 


M16C/26B acer 


> 16MB Space 
> 32-bit arithmetic 
> Barrel shifter 
> DMA 4ch + DMA II 
> 4KB data flash (virtual EEPROM) 
Binary a ae 
compatibility MIGC PLAIFORMiNew CISC) 
with the Vi 1 6C/60 
same CPU e*|’ 1MB space 

> 16 to 32MHz 

> 16-bit multiplier 

> DMA 2ch 

> 4KB data flash (virtual EEPROM) 


MISC Tiny(New CiSC) 
Vi16C/Tiny 


> 3 man pac agg (42 to 80pins) 
> 10 to 

> Single- oe ony 
+ 4KB data flash (virtual EEPROM) 


24MH7@4 2-5 5V 


64KB Flash 128KB Flash 


24K to 64KB ae 48K to 128K Flash EE 96K or 128KB Flas 
AK to 12KB RAM 4K to 12KB RAM 





Figure 1. The M16C platform ranges from the R8C/Tiny up to the R32C/100 series with 32-bit CPUs. 


18 


well-known M16C family and brought 
out its new R32C 32-bit controller. 
The R32C is based on the M16C (Fig- 
ure 1), including its peripheral details 
and programming techniques, which 
means that to a large extent existing 
code and functions already developed 
can be used afresh. Only the core itself 
has been changed, in order to support 
a comprehensive 32-bit architecture. 
The benefits are very obvious: if you're 
already familiar with microcontroller 
structure — even the R8C for instance 
— you'll have no difficulties changing 
up to this new 32-bit derivative. 


Memory magnitudes 


The R32C provides internal flash mem- 
ory that is available in sizes from 256 
up to 1 MB according to requirements. 
RAM also comes in a variety of dimen- 
sions and on the R32C/111 these are 
even independent of the Flash memory 
volume. 


The multiplicity of potential appli- 
cations makes this kind of flexibility 
vital. For example if you are designing 
a display for large text arrays in multi- 
ple languages, you will require plenty 
of flash memory but not much RAM. 
Designing a communication mod- 
ule would call for exactly the oppo- 
site. Here a relatively large amount of 
RAM is required to handle communi- 
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cation stacks, whilst a smaller quota 
of flash memory is called for. Rene- 
sas has christened these combination 
options, shown in Figure 2, with the 
name FlatRAM™. 

A further advantage of this flexibility 
is seen at development phase. It’s now 
a reality for designers to select a chip 
with the maximum amount of mem- 
ory available and further down the 
line refine the specification, replacing 
it with a device using the minimum 
necessary RAM and flash resources. 
This helps you manage the purchase 
budget far better, putting a smile on 
the face of all the bean counters. 


Heart of the system 


Figure 3 is a block diagram of the 
R32C/111. The core — the new 32-bit 
CISC MCU — is based on the proven 
Von Neumann architecture. It includes 
two register banks with a total of six- 
teen 32-bit universal address registers 
and four 32-bit frame/static base regis- 
ters. The majority of the 108 CPU com- 
mands require only one to three CPU 
clock cycles for execution, which dem- 
onstrates the high performance of the 
CISC core. Further features enhance 
the processing speed for arithmetic 
calculations in particular: 


© Hardware multiplier: 32 bit x 32 bit 
= 64 bit 
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@® Repeat Multiply and Accumulate 
(RMPA) with 32 bit x 32 bit + 64 bits 
> 64 bits 

@ Floating Point Unit (FPU) with simple 
accuracy to the IEE 754 Standard 

@ 32-bit Barrel Shifter 

@ 64-Byte Instruction Queue 


The maximum clock rate of the 
R32C/111 device amounts to 50 MHz, 
along with a minimum command cycle 
time of 20 ns. Taking into account the 
overall performance, this controller 
achieves 42 Dhrystone MIPS. But it can 
manage even better: by reducing the 
most significant and most frequently 
used op-codes to just one byte long, 
the program code can be optimised 


| S3kByte |__ 256kB/63KB __ _ 384kB/63kB | 
R32C/111 


FlatRAM J j R32C/111 


100pin LQFP 


| 40kByte 256kB/40kB 


ik 384kB/40kB 
 FlatRAM TT R32C/1411 77" R390/444 





more tightly, so that the processing 
speed can be increased further, with 
less need for flash memory. 


Maths genius 


Let’s now take a closer look at the 
arithmetic qualities of the controller. A 
floating point unit has been integrated 
in the CPU of the R32C. Known as an 
FPU for short, this well-known feature 
speeds up calculations that used to 
occupy so much time and produces a 
speed improvement factor of around 
50. Floating point calculations we 
could mention include accumulating, 
multiplying, dividing, subtracting, con- 


* Constant 
RAM size for 
all Flash variations 


512kB/63kB 
R32C/111 
I 
l 
I 
512kB/40kB 
R32C11 7 
L 


_— i : 


Flash 256KB 


384KB 





512KB 


Figure 2. With the R32C111 Renesas offers a variety of flash memory options for a given RAM array. 
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verting, comparing and rounding. If the 
FPU is not needed, however, it can be 
turned off easily as a compiler option in 
the development environment. 


In addition the R32C also provides a 
32-bit multiplier, a 32-bit Barrel Shifter 
and a Repeat Multiply/Accumulate 
function very handy for filter calcula- 
tions. This comprehensive arithme- 
tic capability also makes the control- 
ler suitable for many applications that 
require DSP functionality. 


A further significant feature for cur- 
rent applications is the rapid reaction 
to Interrupts external to the system. To 
this end the register sets in the R32C 
core are duplicated. When an Inter- 
rupt is called switching between the 
register banks can be effected rapidly 
without time-consuming Push and Pop 
instructions with access open to the 
stack. This switching is achieved sim- 
ply by setting a Flag (see Figure 4), so 
that the Interrupt reaction time can be 
crunched down to just 0.1 Us. 


Another peep under the black ‘engine 
cover’ of the R32C reveals some more 
details of how it all ticks. Internally 
the CPU is connected to a 64 bit-wide 
memory bus, in order to ensure the 
fastest possible data exchange. If you 
examine the 16-bit peripheral bus, you 
will spot components already proven 
in the M16C family to match up to a 
32 MHz data rate. The external 16/8- 
bit bus also reaches 32 MHz and by 
using the four Chip Select lines, it can 
address up to 64 MB externally and 
this with individual Wait States per 
selected domain. 


Control of the internal buses is handled 
by the Bus Interface Unit (BUI). 


On the periphery 


“Seen one, seen them all” — or so it 
might appear. Peripheral functions are 
based on the trusted structure of the 
M16C family, enabling you to re-use 
code that you have already written 
and profit from the collective know- 
how assembled up to now. 


When it comes to interference protec- 
tion and emissions the R32C is well 
equipped. Reduced electromagnetic 
interference (EMI) products, high elec- 
tromagnetic susceptibility (EMS) pro- 
tection and modest power dissipation 
simplify circuit layout at the design 
and planning stage. As with all pre- 
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Peripheral functions 


Timer 
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Figure 3. Block diagram of the R32C/111. 


Dual Bank of Registers 


SWITCH 


Active when bank 
bit “B” in flag 


Active when bank h 
bit “B” in flag j 
gi = 


Good for entering 


interrupt: 


Do not need to save 


to stack when 
switching to another 
bank. (Push....Pop) 


Single set of registers Always 
active, regardless of bank bit 





Figure 4. The register sets in the R32C core are duplicated in order to shorten the Interrupt reaction time to just 0.1 jus. 


vious controllers of the M16C series, 
the R32C is also pin-compatible with 
its predecessors such as the M16C62P 
Accordingly you can use it to replace 
controllers already in use without prob- 
lem, if their performance no longer 
meets your requirements. 


Now here’s a round-up of the most 
important peripheral elements. The 
R32C provides eleven 16-bit timers, 
asynchronous and synchronous inter- 


faces, a four-channel DMAC, a 10-bit A/ 
D converter with up to 34 input chan- 
nels and an 8-bit D/A converter. Com- 
panion features include three intelli- 
gent I/O units that can be programmed 
for an extremely varied range of pur- 
poses, such as Input Capture/Output 
Compare function, an additional syn- 
chronous serial interface with variable 
character length and digital filters. 

Within the R32C family you have 
also recourse to controllers that pro- 
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vide a CAN interface (or even two). 
In this way the development process 
can be optimised within a processor 
family according to cost and power 
requirements. 


The controller also distinguishes itself 
by its low current consumption of only 
28 mA at 3 V and 50 MHz clock fre- 
quency. If the clock rate is dropped, the 
current through the internal 125 kHz 
oscillator or an external 32 kHz crys- 
tal can be reduced to below 8 uA. The 
R32C operates on a supply voltage of 
either 3 V or 5 V, with no restrictions 
on the clock rate. 


The R32C, like the other controllers of 
the M16C family, is designed for appli- 
cations in the consumer and indus- 
trial fields. Its versatile functionality 
makes it suitable for use in industrial 
automation, security equipment, gate- 
way functions, motor control or retail 
automation. A number of emulator sys- 
tems are available to developers. Basic 
debugging functions can be carried 


out without additional hardware, as on 
the R8C13, using the serial interface. 
We'll describe this process in greater 
detail in the next issue of Elektor. If 
you prefer a more comfortable debug- 
ging environment or need more func- 
tions you can employ the E8a or the 
E30a Debugger. 


For your software development envi- 
ronment the HEW4 (High-performance 
Embedded Workshop) is at your dis- 
posal. This software package contains 
an Editor, C-Compiler, Debugger and 
Project Manager in a single combo and 
is ready for you to download gratis on 
the Renesas website. After installa- 
tion all features of the Compiler can be 
used immediately. After a trial phase 
of 60 days it becomes limited to 64 kB 
of code. Alternatively an unrestricted 
KPIT GNU C Compiler is in preparation 
and this allows debugging with the 
HEW. More on the theme of software 
and downloads in the next issue. 
(080082-1) 


Robotics 


Robot kits, parts, accessories, 
and sensors for education and hobby. 


www.parallax.com 
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Reinschmidt 

is an applications 
engineer with Glyn 
Germany, where 
he holds special 
responsibility for 
the M16C and 
R32C microcon- 
troller range. His 
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next exercise for Elektor is a small sam- 
ple application using the R32C carrier 
board, which we will make available in 
the Elektor Shop. Also in preparation is a 
joint collaboration with Elektor Labs for 
an application board for projects using 
OLED displays... 


Bernd Westhoff 
at Renesas 
Technology Europe 
looks after prod- 
uct marketing of 
the M16C, M32C 
and R32C MCU 
series to consumer, 
industrial and dis- 
tributor markets. 
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(sees HV POWER SUPPLY 


T-Reg 





Jan Didden (The Netherlands) 


This article describes a novel design for a high- 
voltage regulator that is very simple yet offers 
excellent performance. The output voltage is 
fully adjustable with a single resistor without 
any changes in performance. You can use 
several types of valves or MOSFETs 


for the pass device in the circuit. 


Quick Project Specs 


A high-voltage r 


for valve amps 










® Universal design, output voltage easily adjustable with one resistor 


© Low output impedance and low hum and noise over the complete audio band 


© Output voltage adjustable between 0 and 500 V, up to 1 A output current 


e Usable for valve preamplifiers and (single ended) power amps 


è Build-in delay function (30 s) for output voltage after power-on 


© Three plug-in options available for the pass device: 
with 6528 valve (max. 600 mA); 
with EL84/6BQ5 or EL86/6CW5 valve (max. 50 mA), 
or with DN2540 MOSFET (max. 1 A) 


Valve amplifiers can benefit from 
regulated and stabilised power sup- 
plies, especially sensitive preamplifier 
stages, but also (single-ended) power 
amps. The assumption is that a DC 
power source is, well, just that: direct 
voltage, i.e. with no hum, noise and 
ripple from the signal frequency. 

But there’s always ripple and noise 
from the power lines through the recti- 
fier and smoothing circuits. Even if you 
get fancy with C-L-C-etcetera circuits, 
it’s never completely clean. And the 
load current, which varies with signal 
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frequency, flows through the internal 
resistance of the supply and Mr. Ohm 
showed us that [current x resistance] 
causes a signal-related voltage on the 


supply. 


Every amplifier has a property called 
Power Supply Rejection Ratio (PSRR). 
That is a measure of how much of the 
ripple and hum on the supply bleeds 
through to the output. It varies with 
amplifier topology, but it’s always 
there. Especially single-ended circuits 
are poor performers in this respect. 





So, a regulated supply that mini- 
mises ripple, noise and hum on the HV 
supply line is quite useful for clean, 
undistorted sound. Traditional high- 
voltage regulators add several extra 
valves, complexity and power losses, 
while good performance is not easy to 
obtain. 


This article describes a novel design 
that is very simple, yet offers excellent 
performance. Output voltage is fully 
adjustable with a single resistor with- 
out any changes in performance. 


Concept 


The concept of my circuit is shown 
in Figure 1 (how I got the idea is 
described in the inset). You're looking 
at a high-voltage regulator, but with- 
out relatively rare and expensive high- 
voltage devices and parts. That’s why 
there is a separate low-voltage supply, 
floating on top of the high-voltage out- 
put. This low-voltage supply, powered 
from the rectified pass valve heater, 
runs the reference and control circuits 
which can be low-voltage stuff. 

This type of regulator always consists 
of the same parts. There is always a 


elektor - 3/2009 


reference voltage and an error ampli- 
fier that compares the reference volt- 
age to (a sample of) the output volt- 
age. The error amplifier then drives 
the pass element to keep the output 
constant. 


In my circuit, the reference voltage 
comes from resistor R3, driven from 
the floating constant-current source 
T1. Transistors T2 and T3 form the 
error amplifier. It is a differential ampli- 
fier but with complementary devices 
rather than a difference amp with two 
like devices. But it works the same: the 
reference is input at T3, and the out- 
put voltage at T2. If the output volt- 
age starts to fall below the set value, 
T2 will start to conduct harder and the 
drive voltage for the pass device across 
R5 will increase. This in turn raises the 
output until it is again at the set value. 
When V becomes too high, the drive 


out 
is reduced, lowering Vut down to the 
set value. Since Vut 1s equal to Vef 
except for a 2 V,., offset, in principle 
you can set the output voltage to any- 
thing you want by just selecting R3. 

This is a great advantage to more con- 
ventional setups. Traditionally, you 


would have a reference voltage that 
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Figure 1. T-Reg conceptual diagram. 
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Figure 2. T-Reg output impedance plots. 


is some fraction of V 


out and then you 
divide V,,,, down to V 


ref Þefore feeding 
it into the error amplifier. If you want 
to change V ut considerably you would 
need to change the division ratio. 

The disadvantage is that this also 
changes the gain of the control loop. 
This in turn means that the perform- 
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EL84 (300V/32mA) 
6528 (240V/240mA) 
DN2540 (310V/140mA)] | 





ance and stability change with output 
voltage. By using a reference voltage 
equal to V ut: as I have done, the stabil- 
ity and performance of the circuit does 


not change with output voltage. 


The error amplifier is a simple circuit 
rather than a high-performance opamp. 
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Figure 3. T-Reg output hum & noise plots. 
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Opamp-based very high gain circuits 
come with their own issues regard- 
ing stability and compensation, for 
instance. In fact the circuit is already 
pretty high performance, as shown in 
Figures 2 and 3. One reason for the 
good performance is that the load 
resistor for the error amp is the resis- 
tor from Varive to ground, R5. Using a 
valve as a pass device, this resistor 
forms the grid resistor, which should 
be around 500 KQ, depending on the 
device. So, even a very small error volt- 
age between the base and emitter of 
T2 will lead to a relatively large ‘correc- 
tion’ current through R5, and thus toa 
quite large correction voltage at V jrive- 
This loop gain is pretty large notwith- 
standing the simple circuit. 


Practical circuit 


This being a valve regulator, there are 
a few other things to take care of. One 
is the delayed application of the anode 
voltage, not just for the pass device but 
also for the amp to be powered. The 
full circuit (without the pass device) is 
shown in Figure 4. IC1 is a standard 
555 (CMOS) timer that pulls down the 
LED in IC3 some time after the sup- 
ply is switched on. The delay is set by 
R8 and C3 and with the given values 
is about 30 seconds. Once the LED in 
IC3 is on, the opto-triac will fire and 
switch on thyristor TH1, which will 
apply the rectified high-voltage to the 
pass valve. 


I used the heater (filament) voltage to 
power the reference and control cir- 
cuits through rectifier B1 and capaci- 
tor C2. 


An important factor is the ‘purity’ of 
the reference voltage. If there is any 
hum or noise on the reference, it will 
be duplicated ‘big time’ by the error 
amp on the output. Current source T1 
gets its reference V,, through LED D5. 
With R1 at 1.3 kQ, the reference cur- 
rent is almost 1.00 mA which makes 
the selection of the reference resis- 
tor R3 easy: just 1 KQ for every volt of 
HV output you want. LED D5 acts asa 
voltage source, and to improve further 
on that, it is biased by constant-cur- 
rent regulator IC2, an LM334. 


There are some other parts on the sche- 
matic for protection purposes. Fuse F1 
protects the high voltage. Next, there’s 
protection for the transistors. For exam- 
ple, if the high voltage is switched on 
by TH1, the reference voltage at the 
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Obsolete? 


The idea for this project came to mind when | was working on a defective 1970’s Lambda 250 V lab power supply. After spending a few hours 
on it, | found the problem: a defective voltage regulator IC, a 14-pin Lambda type FBT-00031. Tech support at Lambda kindly provided a single 
spec sheet for the chip. It took me several more weeks until someone on the Internet identified the chip as a re-branded Motorola MC1466 (fig- 
ure 1). Obsolete, of course! 





So far so good. Then | received 
an email-copy of the June 2008 
issue of LT Magazine. It featured 
the new LT3080 Linear Regula- 


tor (figure 2) that looks conceptu- | Vconrro |_| 
ally very much like an MC1466 Om A 
that was declared obsolete more 


than a decade ago. What’s more, 
this chip was selected by EDN 

as Innovation of the Year, while 
LT’s Chief Technical Officer Bob 
Dobkin was named Innovator of 
the Year. | guess one should be 
very careful with what's declared 
obsolete... 


| found two NOS sources: one Far East at the tune of $ 280 each with a minimum order of 4 (!), the other in nearby Germany for 6 euros each. 
| ordered a couple, replaced the chip and the supply worked perfectly. | found the conceptual approach of this chip, with a floating error amp 
and reference setting with a single resistor so intriguing though, that | decided to see if | could apply it to a high-voltage valve regulator. This ar- 
ticle is the result. 


OUT 
0801089 - 17 
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COMPONENT LIST 


main board 


Resistors 

RT = 1kQ3 

R2 = 1393 

R3 = 250kQ (see text) 
R4 = 330Q 

R5 = 560kQ 

R6 = 3kQ6 

R7 = 470kQ 

R8 = IMQ 


t R9,R13 = 120kQ 
ı R10 = 12Q (see text) 
| RIT = 2kQ2 


R12 = 10kQ 
R14 = 820Q 
R15 = 1kQ 

Capacitors 


C1 = 1uF 560V MKT 
C2 = 1000 uF 16V 
C3 = 22 uF 15V 
C4,C5 = 4uF7 300V 
C6,C7 = 47uF 500V 


Semiconductors 
IC1 = LMC555 
IC2 = LM334 


Lbk n A ee ee l M 


collector of T1 needs time to ramp up 
by charging C1. D2/D8 limits Vo, for T1 
to a safe value during start-up. Protec- 
tion for T2 is also required for the same 
reasons: Vo, Of T2 is limited to 100 V 
by D1. This means that V,,,,. can be 
up to 100 V negative with respect to 
Vut Which is the cathode voltage of the 
pass valve. This value should be suf- 
ficient even with low-mu triodes and 
low load current. R14 limits the maxi- 
mum current through the small-signal 
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TH1 = C106M1G (thyristor for 600V 2.5A) 
IC3 = TLP3052 


T1 = BC556 

T2 = 2SA1208 

T3 = 28C2910 

D1 = 100V 5W zener diode 
D2 = 15V 0.5W zener diode 
D8 = 1N4148 


D3,D4,D6,D7 = UF4007 (fast/soft recov- 
ery rectifier 1000V 1A) 


D5 = LED, yellow, 5mm (.2“) pitch 
D9 = LED, red, 5mm (.2“) pitch 
D10 = LED green, 5mm (.2") pitch 


B1 = DFOOSM (bridge rectifier 50V/1A) 


Miscellaneous 

Fl = 1A fuse, round, plug-in 

K1 = 3-way PCB screw terminal block, lead 
pitch 5mm (.2”) 

K2,K3,K4 = 2-way SIL socket strip 

K5,K6 = 4-way SIL socket strip 

K7,K8,K9 = 2-way PCB screw terminal 
block, lead pitch 5 mm (.2”) 

DIL-06 IC socket 

DIL-08 IC socket 

4 standoffs, h= 12mm (.5”) 

4 machine screws for standoffs 

PCB, ref. 081089-1 from 
www.thepcbshop.com 
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transistors during start-up and tran- 
sient conditions. 


Configurations 


Since this supply is pretty universal as 
regards its output voltage, I also tried 
to make it flexible as to the current it 
can supply. The rectifier, reference and 
control circuits fit on a ‘motherboard’ 
type of PC board (Figure 5). Then there 
is a small plug-in board that carries the 


pass device and some resistors. This is 
plugged on to the motherboard. This 
way, you can use the regulator with 
different pass devices depending on 
your load current. Currently, I have 
three plug-in -boards (see head illus- 
tration): for power amps, the plug-in 
board with a 6528 dual triode valve can 
deliver up to 600 mA (with a suitable 
power transformer, of course). 


A type 6080 valve would also fit on this 
board. Due to its lower mu, it has a 
slightly higher Zut and slightly higher 
hum and noise, but if you happen to 
have one of those lying around it can 
be used with good results. The plug-in 
fitted in the picture is a board with an 
EL84/EL86 (6BO5/6CW5) type triode- 
connected small pentode for preamps 
and similar loads, up to 50 mA. Lastly, 
for those who want a ‘green’ version 
and save 10 watts or so on the pass 
valve heater, there is a board with a 
depletion-mode MOSFET type DN2540. 
This plug-in-board can accommodate 
two DN2540s and their heat sinks 
for an output load of more than 1 A, 
depending on the dissipation from the 
Vps drop. 


The circuits for the plug-in boards are 
shown in Figure 6. Since the 6528 
(6080) is a dual triode, there are small 
value cathode resistors to equalise the 
currents at higher loads. The same 
is used on the DN2540 board in case 
you use two devices for increased 
load capacity (you can short out the 
source resistor if you use only a single 
DN2540). The plug-in -boards also have 
the grid and gate stopper resistors to 
aid stability. The DN2540 board has 
an additional 100 V/5 W zener diode 
(D5/D6) to protect the MOSFET dur- 
ing switch-on and load transients as 
well as Vos protection zener diodes. 
It will also accept a pair of standard 
heat sinks. The boards are connected 
with standard 0.1-inch (2.5 mm) pitch 
PCB connectors and headers cut to 
size. Note that when you use the 
MOSFET pass device you don’t need 
the heater connectors between the 
two boards. M3 machine screws and 
12 mm stand-offs secure the plug-in to 
the motherboard. 


Performance 


Figures 2 and 3 show the output imped- 
ance and output hum and noise of the 
various versions over the audio band. 
Hum and noise under load is typically 
below 500 UVpyg in a 20 kHz band- 
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width for all versions. The DN2540 is 
the best performer because of its high 
transconductance, and it has another 
advantage: a lower drop-out voltage. 
The DN2540 works fine with just 10 or 
15 V Vps (depending on the input rip- 
ple), while the valve versions require 
several tens of volts between anode 
and cathode to operate cleanly. This 
means that for a given transformer 
the DN2540 gives you 10 to 15 V more 
DC output and proportionally less dis- 
sipation. But there’s more to it than 
just measurements. You may prefer a 


valve regulator in a valve amplifier for 
perfectly sound reasons. The choice is 
yours! 

Figure 7 shows the component stuff- 
ing plans for the plug-ins. 


Customisation 


If you need an output voltage in excess 
of 500 V, you can use higher rated 
diodes for D3, 4, 6, 7 and higher voltage 
caps for C6, C7. Note that the diodes 
should be rated for at least twice the 
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rectified peak voltage, preferably more. 
You can use a transformer with a sin- 
gle secondary connected to K1 pins 1 
and 3, or a centre- tapped secondary 
with the tap at K1 pin 2. In the latter 
case you can omit diodes D4 and D6, 
of course. 


The board has provisions for a small 
resistor between the two reservoir 
Capacitors (R10) to take the high-fre- 
quency edge off the ripple voltage. The 
12 Q resistance is probably a bit too 
high for load currents above 100 mA, 





Figure 6. Three different plug-in board/pass device circuits. 


so you should experiment with it. Low- 
ering the ripple on the rectified voltage 
will however not bring a proportional 
improvement on V ut because then the 
ripple on Ve will start to dominate. 
The upshot is that the performance is 
pretty well balanced. 

You set V e by selecting R3. The refer- 
ence current being very nearly 1 mA, 
Vet (in volts) = R3 (in kilo-ohms). You 
can also use an external potentiome- 
ter at K7 to set the output voltage, but 
make sure that it is rated for 500 V. The 


minimum V ut depends on the nega- 
tive grid/gate drive voltage needed 
by the pass device; if you make Vef 
= 0 by shorting R3, the DN2540 gets 
pretty close to zero as well, but a 6528 
will not go lower than a few volts or 
even tens of volts (depending on the 
load) because of the necessary nega- 


tive grid bias. 


Construction 


This supply contains several points 
carrying lethal voltages and cur- 


@ 
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rents, including the heat sinks for 
the DN2540s! You are well advised to 
observe electrical safety precautions 
and if necessary seek the assistance of 
an old hand at valve electronics. Dou- 
ble check that the high-voltage input 
is disconnected or turned off before 
doing anything on the board. Carefully 
discharge the high-voltage capacitors 
with a 1 kQ resistor. To avoid body cur- 
rents make it a practice to keep one 
hand in your pocket when touching 
live boards with a meter probe or any- 
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COMPONENT LIST 


6528 plug-in 


t R1,R2 = 1kQ 0.5W, 1% ! 
' R3,R4 = 12Q 2W, 1% 
' V1 = 6528 or 6080 
: K2,K3,K4 = 2-way pinheader 
! K5,K6 = 4-way pinheader ! 
' PCB-mount Octal socket 
' PCB, ref. 081089-2 from 
:  www.thepcbshop.com 
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thing at all. Even when switched off, 
the high-voltage capacitors may still 
have a dangerous charge. 


Caution: the heater supply for the pass 
valve is also used for the reference and 
control circuits, and floats on the reg- 
ulated high-voltage. Do not use this 
heater winding for any other valves in 
the equipment. If you use the DN2540 
plug-in board, you still need a sepa- 
rate floating supply for the reference 
and control circuits. You could also 
use a small separate 5 or 6 Vac trans- 
former, provided it has enough second- 
ary insulation to allow it to float to up 
to the maximum Vut- 


The best is to start with the 
small parts on the mother- 
board, leaving the larger caps 
for last. Take care to mount 
the pins and headers straight 
upright so they will fit 
easily. The transistors 
are below the plug-in 
board and because of 
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COMPONENT LIST 


EL84/6BQ5 plug-in 


© R1 = 1kQ 0.5W, 1% ! 
' V1 = EL84 (6BQ5) or EL86 (6CW5) i 
| K2,K3,K4 = 2-way pinheader 
' K5,K6 = 4-way pinheader 
i PCB-mount Noval socket 
' PCB, ref. 081089-3 from 
' — www.thepcbshop.com 
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COMPONENT LIST 


DN2540 plug-in 


' R1,R2 = 100Q 0.5W, 1% ! 
' ~R3,R4 = 506 2W, 1% 
| D1-D4 = 15V 0.5W zener diode 
' D5,D6 = 100V 5W zener diode i 
| T1,T2 = DN2540 ! 
' K2,K3,K4 = 2-way pinheader 
' Heat sink(s) 4 K/W, e.g. Wakefield 
| 637-20ABPE 
ı PCB, ref. 081089-4 from i 
www.thepcbshop.com ! 
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the height limitation, should be folded 
horizontally backward on the board. 
The same should be done with the 
output electrolytics C4 and C5. You can 
test the motherboard without a plug- 
in, to verify that the delay and thyris- 
tor circuits work. LED D10 should light 
when switched on, while D5 should 
come on after the delay time. (D9 will 
not come on unless you have a pass 
device plugged in). The input voltage 
at K4 should also come on after the 
delay. Next, populate one of the plug-in 
boards, mount it on the mother board 
and check out the whole assembly. 


You can contact me via my website 
www .linearaudio.nl; I will also post 
any additions and tips there. Happy 
building and happy listening! 

(081089-1) 
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No Compromise Oscilloscope 


Other oscilloscopes in this price range 
force you to compromise on ane of the 
key specifications: 
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The FicaScope S000 series is a no 


compromise PC oscilloscope at a price 
every engineer can afford. 





IGS s sampling rate 

250MHz bandwidth 

28M sample buffer memory 
SMSa O Bet AWG built in 
Picoscope 5203 

32M bufer £1195 


PicoScope 5204 
(28M buffer £1795 
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M16C TinyBrick 


Programmable - 





in BASIC 


Dr. Uwe Altenburg (Germany) 


A TinyBrick is a small self-contained 
microcontroller module fitted with a powerful 
Renesas 16-bit M16C microcontroller. A BASIC interpreter 

is installed in the module to simplify software development. 
Beginners will find it an ideal starting out point while more 


experienced users will appreciate its power and convenience. An 


evaluation board is introduced here; together with a TinyBrick we 


build an intruder alarm that sends SMS texts. 


It was way back in the nineteen eight- 
ies when Intel programmed a control- 
oriented version of a BASIC interpreter 
into its 8052 microcontroller. Elektor 
was the first to do practical things with 
it. The chip was called 8052-AH-BASIC 
and the interpreter known as BASIC-52 
became legendary as a result of Elektor 
publications. Many independent com- 
panies quickly recognised the chip’s 
potential, among them Micromint who 
incorporated it together with the nec- 
essary RAM, communication interfaces 
and supplementary logic into their 
Domino modules [1]. By the middle of 
the nineties the company Parallax [2] 
had introduced the BASIC Stamp mod- 
ule which uses either the PIC micro- 
controller or Parallax SX chip. 


While the 8052 BASIC concept was 
originally aimed at the professional 
user, the BASIC Stamp (despite its 
limited memory) quickly found many 
friends within the semi-professional 
and enthusiasts community. The suc- 
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cess of these modules encouraged 
many other companies to produce 
equivalent devices. One popular exam- 
ple is the C-Control range of controllers 
produced by Conrad Electronics [3] in 
Germany. 


The TinyBrick16 module used here 
can be seen as an addition to this list 
but has the advantage of a powerful 
16-bit microcontroller. The M16C is a 
bigger brother of the popular R8C [4] 
which should be well known to regular 
Elektor readers. A TinyBasic interpreter 
[5] is preinstalled in the controller mak- 
ing a simple and compact environment 
ideal for developing control solutions 
to problems commonly encountered in 
the fields of measurement, control, reg- 
ulation and robotics. Regular Elektor 
readers will already be aware of Tiny- 
Basic which was used in the TinyDis- 
play project featured in the May 2008 
edition [6]. In the same way that the 
TinyDisplay PCB for that project was 
made available from the Elektor Shop 







Quick project specs 


TinyBrick processor board: 


® Renesas M16C29 microcontroller 
® 128+4 kB Flash, 12 kB RAM 

© 1x RS485/RS232 (TTL) 

© 1x RS232 (V24 swing) 

© 1x ISP interface 

© 8x PWM (16 bit) 

è 8x ADC (10 bit) 

è 2x INT, 1 x SPI, 1 x I?C 


Kit of parts available, including 
SMD-prestuffed board 


Microcontroller preloaded with 
BASIC interpreter 


PCB available for evaluation board 





we are also offering the TinyBrick mod- 
ule for this project which will be sup- 
plied with the controller and all other 
SMD components already mounted. 
Other components such as the connec- 
tor and crystal are supplied in the kit. 


Circuitry 


The TinyBrick circuit diagram, PCB 
and pin layout is shown in Figures 1, 
2 and 3. At the heart of the module is 
the M16C29 (M30291FC) microcontrol- 
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ler from Renesas. The M16C29 is avail- 
able in either an 80 or 64-pin LOFP 
package. The TinyBrick PCB space 
constraints allow only the 64 pin vari- 
ant to be used. Any external circuitry 
required by the M16C is kept to an 
absolute minimum. R1 and C5 form the 
reset network while C6 is the supply 
decoupling capacitor. An 18.432 MHz 
crystal provides the system clock; this 
frequency can be easily divided down 
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P84/ 
INT2/ZP 


P85/ 
NMI/SD 


VCC 





RESET 6 RESET 


P100/ANO 
P101/AN1 


VREF 


P90/TBOIN 
P91/TB1IN 
P92/TB2IN 
P93/AN24 





P103/AN3 
P104/AN4/KIO 
P105/AN5/KI1 
P106/AN6/KI2 
P107/AN7/KI3 








P60/RTSO/CTSO 
P61/CLKO 
P62/RXDO 
P63/TXDO 

P64/RTS1/CTS1 
P65/CLK1 
P66/RXD1 
P67/TXD1 


34 RXDO 


[e>] 


P00/AN00 
P01/AN01 
P02/AN02 
P03/AN03 


o 


P15/INT3/ADTRG/IDV 
P16/INT4/IDW 
P17/INTS5/INPC17/IDU 


P80/TA4OUT/U 
P81/TA4IN/U 
P82/INTO 
P83/INT1 


P 46 


P1.5 47 
` 1.6 


P2 


o 
D 
P 


P20/OUTC10/INPC10/SDA 
P21/OUTC11/INPC11/SCL 
P22/OUTC12/INPC12 
P23/OUTC13/INPC13 
P24/OUTC14/INPC14 
P25/OUTC15/INPC15 
P26/OUTC16/INPC16 
P27/OUTC17/INPC17 


P70/TXD2/SDA/TAOOUT 
P71/RXD2/SCL 
P72/CLK2/TA1OUT 
P73/CTS2 
P74/TA2ZOUT/W 
P75/TA2IN/W 
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a P30/CLK3 M16C29 P77/TASIN 
Ceo P31/SIN3 
ari P32/SOUT3 
ag pazı pae; CNVSS 
AVSS XIN XOUT XCIN XCOUT VSS 





X1 = 18.432kHz 


X2 = 32.768kHz 


Figure 1. The TinyBrick module circuit diagram. 


internally to generate the standard 
baud rates for serial port communica- 
tion (300 to 115,200 Baud). The chip 
can be clocked at 20 MHz maximum, 
so the crystal used does not represent 
too much of a reduction in processing 
power. A 32.768 kHz watch crystal is 
also fitted and can be used by a coun- 
ter to generate an exact one second 
clock which is useful for real-time clock 
applications. Both crystals are fitted 
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T1OUT 
T20OUT 
R1IN 
R2IN 


T2IN 
R10UT 


9 Í R20UT 
C2+ 
MAX202 


with appropriate load capacitors. The 
watch crystal oscillating frequency is 
particularly dependant on the value of 
its load capacitors (C10 and C11) and 
can deviate a few ppm from its nomi- 
nal value. To produce a more accurate 
clock the seconds count can be peri- 
odically corrected in software by syn- 
chronising to a reference radio clock 
source. The TinyBasic interpreter sup- 
ports this function. 
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MICROCONTROLLERS 


RXD(V24) 
TXD(V24) 
DTR(V24) 
LCD_CS/P1.5 
LCD_RES/P1.6 
LCD_MODE/P1.7 
SOUT/P3.2 
SIN/SCL/P3.1 
SCLK/P3.0 
CARD/SDA/P3.3 
RXD1(TTL)/P7.1 
TXD 1(TTL)/P7.0 
CLK1(TTL)/P7.2 
INTO/CNTO/P8.2 
INT1/CNT1/IRIN/P8.3 
TX+ 

TX- 

RESET 

NMI 

GND 


+5V 
P0.0/ADCO 

PO.1/ADC1 

PO.2/ADC2 

PO.3/ADC3 
PO.4/ADC4/COLO 
PO.5/ADC5/COL1 
PO0.6/ADC6/COL2 
PO.7/ADC7/COL3 

VREF 

P7.4 

P7.6/SOUND 
P2.0/PWMO 

P2.1/PWM1 

P2.2/PWM2 

P2.3/PWM3 
P2.4/PWM4/ROWO 
P2.5/PWM5/ROW1 
P2.6/PWM6/ROW2/DIRO 
P2.7/PWM7/ROW3/DIR1 


TinyBrick16 Manet 





Figure 3. The TinyBrick pinouts. 
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COMPONENT LIST 


TinyBrick module 


! Resistors 
| R2-R7 = 10kQ 
© RI = 100kQ 


Capacitors 
C10,C11 = 15pF 
C7,C8 = 22pF 
C1-C6,C9 = 100nF 


Semiconductors 
IC1 = M30291FC-U5 
IC2 = SN75176 


IC3 = MAX202CSE 


Miscellaneous 
X1 = 18.432 MHz quartz crystal 
X2 = 32.768 kHz quartz crystal 


K1,K2 = 20-way SIL pinheader with turned 


pins, 2.54mm / 0.1” lead pitch 


K3 = 10-way Micromatch socket 
JP1 = jumper 


PCB # 080719-1 [8] 


SMD components; all other parts included. 


Order code 080719-91 [8] 


interpreter. 


PCB, ready stuffed with microcontroller* and 
* programmed with bootloader and BASIC 
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Interfacing 


The M16C29 contains three universal 
asynchronous interfaces (UARTs). The 
first of these serial interfaces using 
pins P6.1 to P6.3 are connected to a 
MAX202 (IC3) and then on to pins 1 to 
3 of the pin-strip connector K1 to pro- 
vide V24 serial communication signal 
levels. This port is used to download 
BASIC applications. BASIC routines 
can also use this port for example to 
send/receive messages or interface to 
a serial display or modem. For this last 
application the DTR signal is also avail- 
able along with TXD and RXD. 

The second interface uses port pins 
P6.4 to P6.7 together with control sig- 
nals (RESET, CNVSS) on the 10-pin 
Micro-Match connector. This port is 
used for In System Programming (ISP). 
When an E8 emulator together with a 
HEW development system (from Rene- 
sas) is used it is possible to download, 
run and debug C programs. Even with- 
out an E8 an additional programming 
adapter has been developed for fans of 
C and will be presented soon in Elektor 
— we have already reserved the url: 
[7]. 
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Figure 4. The TinyBrick evaluation board. 
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Figure 5. Circuit of the TinyBrick evaluation board (The example application is shown in grey underlay). 


The third interface has two functions. 
Firstly it sends and receives signals 
directly on the pin strip connector K1 
at TTL signal levels which is com- 
monly used by equipment such as GPS 
receivers or radio time signal receiv- 
ers. The signals are also connected to 
a SN75176 differential line driver (IC2) 
to provide TX+ and TX- for an RS485 
interface on K1. This allows several 
TinyBricks to be bussed together to 
form a network, a useful feature for 
applications such as home automa- 
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tion. TinyBasic includes support for a 
simple network protocol. 


Evaluation Board 


The minimum circuitry required to run 
a TinyBrick module is a regulated 5 V 
power supply (mains adapter or bench 
power supply) and a serial interface 
cable. The connections can be made 
by plugging the module into a proto- 
typing pin board or using a piece of 
perforated board. A simpler solution 


is to order the TinyBrick evaluation 
PCB available from the Elektor Shop; 
this produces a much neater job. The 
PCB requires very few components to 
be fitted and no special soldering skills 
are required. The evaluation board is 
shown in Figure 4, it provides connec- 
tors for an external power supply and 
a serial communications cable. 


The serial port uses a standard 9-pin 


sub-D connector. This simplifies the 
task of attaching peripherals such as 
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Figure 6. TinyBrick evaluation board PCB. 


modems or displays to the evaluation 
board. A null-modem cable is required 
to download programs but if you do 
not have access to a PC with a serial 
port it will be necessary to make a 
‘null-modem to USB’ cable (use a USB 
to TTL cable together with some RS232 
level shifters). 


Construction details of such a cable are 
available on the Elektor website [8]. 


File Edit Program Controller View Help 
Te. A PF re < 6 | P e % a 
C2\...\TinyEditor?\Samples\, 

23 

24|° ===- Variables -- 

26 byte xn, bAlarm, bedge 

27 

28 Init: 

29 port2.0 = 1 

30 initgsm PiNn,"",20000 
E irRemote.bas | 3 
[E Lauficht.bas 32 
[E Mandebrot-bas | 3 
EE Roborcontrol.bas 4 

x 35 

36 Hain: 

37 if timerd = 0 then 

38 

3| port2.1 = 1 

40 recvama phone, text 

« m 


port2.0 = 0 


TimerO = 1000 


TriyBase Compter V2.2 (c) 2006-2008 www.tnybasx.de 


Compéng... 
>> Cr\Programs\ TinyBasic\ TnyEdRor2\Samples\SerolesmecontroLbas 
Generating... 
>> C:\Programs\ TinyBasi\ Tinyedtor2\Samples\SerpleSmeControLhex 
>> C:\Programs\ TinyBasic\ Tinyedtor2\Samples\SerpleSmeControList 


Code ste: 568 bytes (1%) 
Data ste: 343 bytes (16%) 


3) Build Find C] Console =) Scope 
39: 1 Inser 


if Frr then port2.0 = 0 : pause 2000 


Software 


As mentioned earlier TinyBricks are 
primarily programmed in TinyBasic [5], 
which is one of the easier languages 
for beginners to pick up. Experienced 
developers will also find this system 
has much to offer allowing small tasks 
to be completed in a very short time. 
The M16C29 is equipped with 128 kB 
Flash, 12 kB RAM and 4kB of data 


x Qi B Bp a? Helio Worid’s13810 
* |SimpleSmsControlbas \RobotControl.bes | Hello Worid.bas \ 


25 char phone[(20),text{300),alarm{20) 


, 
init modem (pin number) 


: gato Init 


for messege... 


receive a message from modem 





Figure 7. TinyEditor used to generate and download the TinyBasic program. 
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COMPONENT LIST 


Evaluation board 


Capacitors 
C1 = 100nF 
C2,C4 = 100uUF 16V 


Semiconductors 
IC] = LM2940-5.0 
D1 = 1N4004 


' Miscellaneous ! 
| K1, K2 = 20-way SIL socket strip, 
i  2.54mm/ 0.1” lead pitch i 
K3 = 9-way sub-D socket (female) ! 
' K4 = PCB socket for power line adaptor | 
| K5 = 2-way PCB screw terminal block, 
: lead pitch 5mm (.2”) i 
i K6 = solder pins 
' 2 x 20-way socket for Tinybrick module 
| (2.54mm / 0.1” lead pitch) l 
| 1x protoboard (ca. 84 x 54 mm / 3.3 x 
© 20) ! 
' 1x heatsink type SA220 ; 
| PCB # 080719-2 [8] i 
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flash memory, 64 kB is reserved for the 
boot loader and TinyBasic interpreter. 
The current version of TinyBasic uses 
around 40 kB so there is ample space 
left for future expansion. 32 kB is avail- 
able for use by the Basic program. The 
program is stored in the form of tokens 
so this should be more than enough. 
The remaining 32 KB is free to be used 
as necessary, for example to store data. 
Lastly there is 4 kB of data flash mem- 
ory in which initialisation values and 
other parameters are stored. The data 
Flash memory can be erased and repro- 
grammed up to 10,000 times while the 
normal flash memory is good for up to 
around 1,000 erase/reprogram cycles. 
The Bootloader is called immediately 
after a system reset. If no download is 
detected within the first 2 s the Tiny- 
Basic interpreter begins executing the 
most recently stored BASIC program. 
The bootloader can also be used to 
load the resident TinyBasic interpreter; 
this ensures that any future versions 
of the interpreter with newer features 
can still be used by the current Tiny- 
Brick. While the TinyBrick is execut- 
ing a BASIC program a system reset 
can be initiated by sending a reset 
sequence over the first serial interface 
port. Once this is received a software 
reset is generated and the bootloader 
begins execution again. This allows a 
program download to be initiated at 
any point. 
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A freeware editor is useful for the 
development of TinyBasic programs 
(Figure 7) [5]. It contains all the tools 
necessary to enable programs to be 
written, compiled and downloaded to 
the TinyBrick. The compilation process 
detects and indicates the line number 
of any syntax errors. In addition it 
reduces the size of the finished code 
quite appreciably. 


TinyBasic the basics 


Many system variables are defined in 
TinyBasic. Using the variables portO 
to port9 the status of the ports can be 
read and changed. It is often neces- 
sary to access just a single port pin. 
The line: 


Port2.0 = not Port2.0 


inverts the state of pin P2.0 each time 
it is executed. Variables should always 
be assigned meaningful names to 
help make the program listing more 
readable: 


#define Motor Port2.0 


#define ON 1 


allows us to turn on a motor connected 
to port pin P2.0 using the command: 


Motor = ON 


When the processor is reset it restarts 
with all of its port pins configured as 
(high impedance) inputs. This ensures 
that there are no signal conflicts with 
any externally connected hardware. 
Using the ‘setport’ instruction any of 
the port pins can be defined as an out- 
put. Pull-up resistors can also be con- 
nected to inputs pins under software 
command. As an example: 


setport 2,%700000001, 411110000 


will configure pins P2.4 to P2.7 as 
inputs with pull-ups, pins P2.1 to P2.3 
as inputs without any pull-ups and pin 
P2.0 as an output. 

One special feature of TinyBricks is its 
direct support for different types of text 
and graphic displays. The Display On 
Glass Module (DOG-M) from the com- 
pany Electronic Assembly [9] offers a 
number of advantages over other dis- 
plays, for example its use of an SPI 
interface means that it only uses five 
of the controllers port pins. Interfacing 
a graphic display module has already 
been covered in more detail in the pre- 
vious article [6]. 

Only one command is required to indi- 
cate to the BASIC interpreter which 
type of display is fitted. This informa- 
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Figure 8. The small intruder alarm built using the evaluation board. 


tion determines which output com- 
mand is used to write to the display 
i.e. move or print. In this example a 
three line text display with 16 charac- 
ters per line is defined: 


setdisplay LCD DOGM16x3 


This display incorporates its own char- 
acter set so it is only necessary to send 
the code for each character to the dis- 
play. When a graphic display is fit- 
ted it is necessary to send the pixel 
pattern for the character to the dis- 
play. A graphic display also allows 
lines, circles and other symbols to be 
represented. 


Another basic concept in TinyBasic is 
the difference between the five input 
and five output channels. Channels #0 
and #1 are assigned to the first two 
serial interfaces, while channel #2 
writes to the display and reads from 
the attached keypad. Channels #3 and 
#4 allow two independent files to be 
referenced on a SD card. 


The following two-line example dem- 
onstrates how the channels are used 
to send the text string ‘Hello World!’ 
first to the serial interface and then to 
the display: 


4 


print #0, “Hello World!” 


sends the text to the first serial inter- 
face, while 


print #2, “Hello World!” ~ 


sends the text to the display. 

There are many different text features 
supported in the language such as 
using (), chr () and spc () which are 
useful for text formatting. 


A first project 


As an example application we will use 
the evaluation board fitted with a Tiny- 
Brick to build an intruder alarm (Fig- 
ure 8). The proposed alarm is quite 
simple but should be sufficient to pro- 
vide some security to the contents of, 
say, a garden shed. The alarm becomes 
armed once the door is closed and will 
be activated when it is opened. A lim- 
ited time window allows the correct 
PIN code to be entered to disable the 
alarm before the break-in is detected. 
The alarm is fitted with a display and 
sends an SMS text to a predefined tel- 
ephone number. 


The grey underlay on the circuit dia- 
gram in Figure 5 shows the compo- 
nents used. Characters are displayed 
on a three line ‘DOG’ display module 
from Electronic Assembly. A 3x4 foil 
matrix type keypad is used to enter the 
PIN code and a small microswitch is 
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fitted behind the door strike plate to 
detect the door opening. The alarm 
sound can be produced by a 12 V 
siren but this is quite deafening in a 
small space and not really necessary 
because an SMS text is also sent at the 
same time, a small loudspeaker should 
therefore be sufficient. 

To send the SMS texts over the cell- 
phone (GSM) radio network it is neces- 
sary to use a GSM modem with a serial 
interface such as the basic TC35i from 
Siemens. The company Telit [9] also 
offer a more integrated solution with 
its GM862-OQUAD modem with multi- 
band GSM and GPRS capability. These 
stand-alone GSM modems all turn out 
to be relatively expensive. A better 
solution is to use an old mobile phone. 
Newer models are usually unsuita- 
ble because they are not fitted with a 
serial interface port. Some of the older 
types of phone also have the prob- 
lem that the serial port is not availa- 
ble when the charger is attached and 
vice-versa. 


The trusty old Nokia 63101 mobile 
phone is ideal for this application 
because it has a serial interface and a 
separate charging socket. The phone 
also supports “Text Mode’ for sending 
SMS texts. It is also necessary to use 
the Nokia DLR-3P data cable to connect 
to the phone. This is powered from the 
DTR signal so it is necessary for the 
program to switch this line to +12 V. 
The complete source code for the 
project can be freely downloaded from 
the Elektor website [8]. A fragment 
of the code for the intruder alarm is 
shown in Listing 1. The program has 
been kept deliberately simple; for 
example the phone number to which 
the text is sent is defined in source 
code and can be changed by the text 
editor but there is no reason why the 
program cannot be modified so that 
one or more numbers entered from 
the keypad can be stored for exam- 
ple in the data Flash memory of the 
microcontroller. 


I am sure you have thought of other 
applications where it would be useful 
to send or receive SMS texts on your 
mobile. The unit could for example be 
incorporated into a heating system 
controller to call the heating engineer 
when a fault occurs. A routine could 
also be written in TinyBasic to receive 
and decode SMS text messages and 
use the TinyBrick I/O capability to con- 
trol processes appropriately. 

(080719-1) 
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Listing 1. The intruder Alarm source code (fragment) 


` --- Main loop --- 
do 
` The door was just locked... 
if (State = NONE) and (Door = LOCKED) then 
cls 
print #2,chr (0) ‘ print special char 
move 5,1 
print #2,”ARMED” 
State = ARMED 
pause 1000 
endif 


` The door was just opened... 
if (State = ARMED) and (Door = OPENED) then 
cls 
print #2,”Enter Pin Code:” 
move 6,1 


PinOk = 0 

PinNum = 0 

Timer = T30SEC 

State = WAITING 
endif 


` Time elapsed... 
if (State = WAITING) and (Timer = ELAPSED) then 
cls 
print #2,”Init modem Y 
initgsm 8034 
` init gsm modem with pin code 
if Err = 0 then print #2,”OK”, 


print #2,”Sending SMS a 

sendsms “0174xxxxxxx”,”Burglary!” 
` send sms with message text 

find “OK”,15000 


if Err = 0 then 
print #2,”OK”, 
print #2,”Alarm...... a 


for nAlarm = 0 to 50 ` alarm siren 
for nFreq = 3000 to 2500 step -50 
sound nFreq 
next 
next 


print #2,” READY”, 
endif 


State = NONE 
endif 


loop 


bacen R a a a M M M M M H M 


Internet Links [6] www.elektor.com/070827 


[1] www.micromint.com [7] www.elektor.com/080422 (to be 
[2] www.parallax.com published) 

[3] www.c-control.de [8] www.elektor.com/0807 19 

[4] www.elektor.com/r8c [9] www.lcd-module.de 

[5] www.tinybasic.de [10] www.telit.com 
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EUEN CPLD & HF 


Sinewaves in Progra 


Direct digital synthesis using an Altera CPLD 


Jean Christophe Humez (France) 


Generating a stable, high-frequency signal from a crystal is simple, but you can’t always get just the 


frequency you want. Of course, you can always order custom-made crystals, but not everyone can afford 


this and it’s not necessarily terribly practical. A more flexible solution is direct digital synthesis (DDS). 


Ready-made DDS devices do exist, but are complicated to use. Here’s a compromise between the 


flexibility of a DDS device and the inflexibility of a crystal: programmable logic. 


Technical specifications 


© DDS frequency synthesizer (Direct Digital Synthesizer) 


© Sinewave output by virtue of the principle and the filtering 


© Output frequency from 610 Hz to 28 MHz with a resolution of 610 Hz 


è Possibility of performing FSK (Frequency Shift Keying) frequency modulation 


© EPM7064SLC44-10 (or LC44-7) programmable logic IC from Altera 


© 70 MHz operating frequency 
@ R-2R network DAC 
© Output filtering using an LC circuit 


@ 5 V supply 


Oscillator 


70 MHz 
Xtal 


16 amplitude levels 


increment on each per sinewave period 


clock pulse 
converter 
16-bit register 


Incremented with 25390 
(decimal) 


sinewave ROM 


phase accumulator i 4 most * 
significant bits 


CPLD 


Figure 1. Block diagram of the DDS generator. 
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Programmable frequency generators 
have been published before in Elektor 
[1][2], but they used a special IC based 
on a phase locked loop (PLL). 


Here we're going to apply a different 
principle to arrive at the same result. 
We're talking about circuits that syn- 
thesize sinusoidal signals directly 
(DDS — Direct Digital Synthesis), 
which allow us to generate specific 
frequencies with great precision. They 
are a digital solution in competition 
with solutions using PLLs. Integrated 
circuits do exist to achieve this func- 
tion, but there aren't all that many of 
them around. 


The AD98xx series from Analog Devices 
is a family of DDS devices with vary- 
ing degrees of speed and accuracy, but 
these ICs are hard to implement, espe- 
cially if you only need to generate a 
single frequency. They have to be con- 
figured using internal registers, and so 
need a microcontroller to work along- 
side. Also, they come in extremely 
small packages (28-pin SSOP for the 
AD9851), and fitting them is not always 
within the capacity of amateurs. In this 
article, we're suggesting a simple and 
effective solution based on the princi- 
ple of DDS, but without the complexity 
of a DDS device, that lets us produce 
frequencies that are useful for radio 
applications like the 27 MHz Citizens’ 
Band (CB). Our solution uses a type 
EPM7064SLC44-10 complex program- 
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mmable Logic 


mable logic device (CPLD) from Altera. 
It goes without saying that this solu- 
tion can be used with other FPGA pro- 
grammable ICs, or even microcontrol- 
lers for generating lower frequencies. 


Block diagram 


The heart of a DDS system is a register 
called a phase register or phase accu- 
mulator. This register is incremented 
with a constant at the rate of a stable 
clock. When the phase register over- 
flows, one period of the output sig- 
nal is completed. The overflow is so 
arranged as to reset the register toa 
lower value and a new output signal 
period starts. In this way, the phase 
register behaves cyclically, and it is 
this cycle that generates the frequency 
of the output signal. This technique 
makes it possible to generate any fre- 
quency, with a resolution that depends 
on the size of the phase register. 


A certain number of bits in the phase 
register are then used to index a table 
that contains the waveform to be gen- 
erated — usually a sinewave. The 
larger this table is, the more accurate 
the output waveform will be. 

In our system (see Figure 1) the phase 
register is 16 bits and is incremented 
on each rising edge of the 70 MHz 
master clock with a value of 25,390. 
In this way, the output frequency is 
27.120 MHz. This increment is easy to 
calculate (with a 16-bit phase register 
= 216 = 65,536): 


27.120MHz 
Š 


increment = 65536 X = 25390 


The four MSBs of the phase register 
address a memory containing 16 8-bit 
samples of one cycle of a sine-wave 
(Table 1). An 8-bit R-2R ladder network 
performs the digital-to-analogue con- 
version. The signal is then smoothed 
by an LC filter, centred on 27 MHz, so 
as to obtain a clean sinewave. 


Circuit in detail 


Figure 2 shows the circuit of our 
oscillator in detail. A binary input E | 
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Figure 2. Circuit diagram of the CPLD based DDS oscillator. 


Table 1. Contents of the sinewave ‘ROM’ 


| Input O| Sine function in degrees Output converted to period [0 - 255] 


0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 
1111 


sin(0) 
sin(22.5) 
sin(45) 
sin(67.5) 
sin(90) 
sin(1 12.5) 
sin(135) 
sin(157.5) 
sin(180) 
sin(202.5) 
sin(225) 
sin(247.5) 
sin(270) 
sin(292.5) 
sin(3 15) 
sin(337.5) 





245 
255 
245 
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Figure 3. Example of the digital sinewave before (blue) and after (red) filtering. 


FMA lets us choose between two fre- 
quencies, and so allows binary FSK 
(Frequency Shift Keying) frequency 
modulation. 

The digital sinewave leaves the CPLD 
on an 8-bit port and a DAC is needed 
to convert it into an analogue sine- 
wave. To avoid having to use a special 
device, we are using a resistor net- 
work, referred to as ‘R-2R’ because of 


its structure. Each of the eight outputs 
generates a voltage which contributes 
to the total output voltage. 


The DAC output signal doesn’t look 
much like a sinewave (see Figure 3) 
and a filter is needed to improve it. As 
we have on average only 2.6 samples 
per cycle, lots of unwanted harmonic 
frequencies are generated and need to 


be eliminated. This task is entrusted to 
two LC filters in series. 

The filtering makes use of J310 JFET 
transistors, well-known in HF elec- 
tronics. The LC filters are centred on 
27 MHz, calculated using Thomson’s 
formula: 


frequency =1/(27.{(LC)) 


where L is the inductance and C the 
capacitance. With 33 pF for C and 1 WH 
for L, we get a frequency of 27 MHz. 


The VHDL code 


The CPLD is programmed in VHDL. 
The program breaks down into two 
processes. 


Process 1: the phase accumulator 
This counter operates with a recur- 
rence of 27.120 MHz or 27.125 MHz. 


Listing 1: VHDL program 


The leading - indicates a comment 


-- Direct Digital Synthesiser December 26, 2008 
-- JC HUMEZ 


LIBRARY ieee; 
USE 1eeesstd logic 1164.a1 1; 
USE 666 .sc0 logic uUnsigned.all; 


ENTITY sine dds IS 


PORT - - definition of the CPLD external signals 
( 
-- CPLD inputs 
E CLK IN STD: LOGIC; 7OMHZ master clock 
E FMA IN STD LOGIC; -- (frequency select FMA=0=>27.120MHzZ or FMA=1=>27.125MHz) 
-- (to perform 0 or 1 FSK modulation) 
-- CPLD outputs 
S OUT out std_logic_ vector(7 downto 0) - sinewave amplitude coded in 8 bits 


i 
END sine dds; 


counter ARCHITECTURE OF sine dds IS 
-- definition of internal CPLD signals 


SIGNAL SIG CPT std logic vector(15 downto 0); == phase accumulator 
SIGNAL SIG ESIN std logic vector(3 downto 0); -- 4 MSBs of phase accumulator 
SIGNAL SIG SSIN out std_logic_ vector(7 downto 0) - sinewave amplitude 
BEGIN == start of architecture 
--//-- start of phase accumulator process 
PROCESS (E_FMA,E CLK) 
BEGIN 
IF (E CLK’EVENT AND E CLK = ‘1’) THEN 
IF 3 FMA = *0*% THEN 
--here FMAO 27.120MHz -- formula = 65536/70MHzZ*27.120MHz = 25390 
SIG CPT <= SIG CPT + 25390; 
ELSE 
--here FMA1 27.125MHz -- formula = 65536/70MHzZ*27.125MHz = 25395 
SIG CPT <= SIG CPT + 25395; 
END IF; 
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This is a 16-bit register called SIG _ 
CPT and hence its maximum value is 
216 = 65,536. This process is run on 
each rising edge of the 70 Hz signal, 
defined by the condition: 

E CLK’ EVENT AND E CLK = ‘1’ 
To achieve our repetition rate of 
27.120 MHz, we need to add the whole 


number 25,390 on each rising edge of 
the 70 MHz: 


SIG CPT <= SIG CPT + 25390 


Next, the variable SIG ESIN lets us 
isolate the four MSBs of SIG CPT: 


SIG _ESIN(3 downto 0) <= 
CPT(15 downto 12) 


SIG_ 


Process 2: the digital sinewave 
The second process involves a small 
memory containing the eight bits of 


END PROCESS; 


the digital sinewave, and it too runs 
at each rising edge of the 70 MHz. This 
process causes each of the 16 values of 
SIG ESIN to correspond to one sam- 
ple of the digital sinewave SIG _ SSIN. 
This function is achieved using the 
instruction 


CASE 
WHEN 


The digital sinewave samples are cal- 
culated like this: 


Sample = 127.5 X sin(Naz /8)+127.5 


where N is from 0 to 15. Table 1 gives 
the 16 values stored in the ‘ROM’. 


Construction 


A prototype was made on a piece of 


--//-- end of phase accumulator process 


SIG _ESIN(3 downto 0) 


<= SIG CPT(15 downto 12); 


-- only the 4 MSBs are retained 


--//-- start of memory process 
PROCESS (E_ CLK) 
BEGIN 
IF (E CLK’EVENT AND E CLK = ‘1’) THEN = clock rising edge 
CASE SIG ESIN IS 
WHEN “0000” => SIG SSIN <= “01111111”; --127 
WHEN “0001” => SIG SSIN <= “10110000”; --176 
WHEN “0010” => SIG SSIN <= “11011001"; --217 
WHEN “0011” => SIG SSIN <= “11110101"; --245 
WHEN “0100” => SIG SSIN <= “11111111”; --255 
WHEN “0101” => SIG SSIN <= “11110101”; --245 
WHEN “0110” => SIG SSIN <= “11011001”; --217 
WHEN “0111” => SIG SSIN <= “10110000”; --176 
WHEN “1000” => SIG_ SSIN <= “01111111”; --127 
WHEN “1001” => SIG SSIN <= “01001110”; --78 
WHEN “1010” => SIG SSIN <= “00100101”; --37 
WHEN “1011” => SIG SSIN <= “00001001”; --9 
WHEN “1100” => SIG SSIN <= “00000000”; --0O 
WHEN “1101” => SIG SSIN <= “00001001”; --9 
WHEN “1110” => SIG SSIN <= “00100101”; --37 
WHEN “1111” => SIG SSIN <= “01001110”; --78 
WHEN OTHERS => SIG SSIN <= “00000000”; 
END CASE; 
END IF; 
END PROCESS; 
--//-- end of memory process 


S OUT <= SIG SSIN; 


END counter; 
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-- Sinewave output amplitude coded in 8 bits 


-- end of architecture 


prototyping board with an earth plane. 
There are no adjustments. In Figure 4 
you can see the 70 MHz oscillator, the 
CPLD chip, the three JFET transistors 
with the inductors, the JTAG program- 
ming connector and a 5 V regulator for 
the power. On the back of the board 
(Figure 4b), the R-2R network is wired 
using SMD 0805 resistors. 


Depending on the state (0 or 1) of the 
E FMA input, we get one or the other of 
the two frequencies. This E_ FMA input 
is intended for binary frequency modu- 
lation (FSK). 


Figures 5a and 5b show the circuit's 
two output signals as displayed ona 
digital oscilloscope. 


Programming other frequencies 


The highest frequency we will be 
able to obtain is 40% of the value of 
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Figure 4. Prototype of the circuit on prototyping board (left). The R-2R network is fitted on the soldering side of the board (right). 


the input frequency. In our case, 40% 
of 70 MHz comes out at 28 MHz. Any 
given frequency can be calculated like 
this: 


desired frequency 
70 MHz 


increment = 65536 X 


Which, for a frequency of 12 MHz for 
example, gives an increment of 11,235 
(rounded). 

The filter used here does not allow 
operation over a wide range of fre- 
quencies. To adapt this circuit to a fre- 
quency of 12 MHz, the corresponding 
LC filter will be: 


12 MAz=1/(27,/(LC)) 


Which is (almost) true when, for exam- 
ple, C = 180 pF and L = 1 WH. 


Conclusion 


The circuit shown here is no new inven- 
tion, but a little survey on the Internet 
has shown that this idea of construct- 


2r. 1198MHz 


t 4. 668s 
CHi +e |CH2== j2. 3GS] MAIH |TREIG-~| EDG ACH USE 
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ing it using a programmable device is 
not very widespread. Yet this is a simple 
solution that can cover RF frequencies, 
as here up to 28 MHz, using what is by 
no means the fastest or best-performing 
programmable device. 


It’s not worth struggling to find the DDS 
device you need and then coding the 
software to configure it. It’s much eas- 
ier to build it using more readily avail- 
able devices. The literature on the sub- 
ject is often long-winded and employs 
lots of signal analysis calculations that 
were not helpful in understanding this 
article. 


Here, the CPLD device is only 48% full. 
This leaves you scope to code another 
DDS generator, or else improve this one 
(by increasing the number of bits in the 
phase register, for example, or enlarg- 
ing the digital sinewave table), or to 
output two sinewave signals with dif- 
ferent phases, e.g. two sinewaves in 
quadrature. 

(080750-1) 


t 4, 668s 2r. 1243MHz 
CHi +e |CHe== [2.5655] MAIN |TRIG-~| EDGE ACE USE 
Døm | 386ml | iene CH1 . | AUTO |SAMPLE 


Figure 5. Output signal after filtering: 27.120 MHz (A) and 27.125 MHz (B). The frequency is shown in the bottom right-hand corner. 
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For further reading 
Data sheets for DDS devices, e.g. the AD9851 
from Analog Devices. 
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Thorsten Udelhoven (Germany) 


As an enthusiastic yachtsman, the author of this article is primarily interested in using the SDR receiver 
described in the May 2007 issue of Elektor for receiving marine weather data. However, this requires 
enhancements to the basic design to accommodate the special operating modes of marine weather 
data broadcasts. In addition to the tuning and demodulation software, you need specific weather data 
decoding software and a second sound card. 


This article is based on the author’s ject get started with receiving weather experimenting was necessary between 
experience and is intended to help data using the Elektor SDR receiver [1]. unpacking the SDR module from the 
other persons interested in this sub- A certain amount of handiwork and box and the first weather report dis- 
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played on the screen of the author’s 
notebook computer. However, since 
then the receiver has accompanied the 
author onboard and fulfilled its duties 
faultlessly. 


Weather data broadcasting 


Long-range weather data transmit- 
ters are available for aviation and 
for maritime navigation. For aviation 
applications, they are short-wave SSB 
voice transmitters, such as Shannon 
Volmet at 5505 kHz or RAF Volmet at 
5450 kHz, while for maritime naviga- 
tion they are short-wave or long-wave 
transmitters that broadcast text mes- 
sages using radio teletype (RTTY) and 
NAVTEX (see inset) or weather maps 
using radio facsimile (weather fax, also 
known as WEFAX). 


antenna 


SDR board 


changes to the SDR board are nec- 
essary. However, in addition to the 
standard configuration for receiving 
radio broadcasts with the SDR, you 
need a second sound card and spe- 
cial weather data decoding software. 
The sound card is necessary because 
the baseband signal output from the 
demodulation program (such as Dream 
or SDRadio) must be fed back into the 
PC for processing by the weather 
data decoding software. The weather 
data decoding software provides the 
functions of an RTTY, NAVTEX, or fax 
decoder. 


Second sound card 


There are two options here: you can 
use a second sound card, or you can 
use Virtual Audio Cable. 


Computer 


tuning software 


weather decoder 





Virtual Audio Cable [5] is a program 
that sells for around € 35 (US$ 50) 
and can be used to transfer an audio 
stream from one application to another. 
This avoids the need for a second 
sound card. If you prefer this option, 
you should try the demo version before 
making your final decision in order to 
ensure that the software works prop- 
erly with your specific hardware con- 
figuration. The most economical solu- 
tion is the USB sound card, which 
should work properly with all comput- 
ers running Windows XP or later. 


SDR tuning software 


Version 2 of the SDR tuning software 
[6] written by Burkhard Kainka (Elektor 
SDRadio2), which was described in 
the September 2007 issue of Elektor 


demodulator 


NAVTEX 
Weather FAX 


Figure 1. Elektor SDR configuration for receiving marine weather transmissions. 


These transmitters are operated by 
national meteorological services, such 
as the Met Office in the UK and the 
NWS/NOAA in the US, according to 
fixed broadcast schedules that spec- 
ify the transmission frequencies and 
times [2a][2b]. A worldwide compen- 
dium of marine weather broadcasting 
stations is available on the website of 
the US National Weather Service [3]. 


SDR enhancements 


Figure 1 shows the SDR configuration 
for receiving marine weather data. No 
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If your PC does not already have a 
second sound card, a mini-USB sound 
card is an attractive option. The author 
used a Speed Link model [4], which 
works under Windows XP or later as a 
plug & play device that is ready to use 
right after it is plugged into a spare 
USB port. The technical demands on 
the second sound card are relatively 
modest, in contrast to the first sound 
card, which is used to feed in the in- 
phase and quadrature signals and 
must therefore have stereo input, an 
anti-aliasing filter, and the highest 
possible sampling rate. 


Electronics, has a tuning range of 
30 kHz to 30 MHz with a step size of 
1 kHz (Figure 2). This range and reso- 
lution are perfectly adequate for this 
application. Nevertheless, the author 
wrote a special version of the tuning 
software for receiving weather data, 
so that the most important frequen- 
cies and DWD transmission sched- 
ules could be selected or displayed 
directly. It is based on the source text 
of Elektor SDRadio2, and it is included 
in the downloads available for this 
article [7] on the Elektor website. In 
this version of the program, the fre- 
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quencies are arranged in col- 
umns labelled NAVTEX, FAX, 
RTTY1, and RTTY2 in increas- 
ing order of frequency. If the 
frequency at the top of the list 
does not yield adequate sig- 
nal strength, you can select 
one of the other frequencies 
in the list. In principle, the 
further away the transmit- 
ting station is, the higher the 
selected frequency should 
be. 


Demodulation software 


A variety of demodulator pro- 
grams can be used with the 
Elektor SDR module. The two 
programs used by the author 
— Dream [8] and SDRadio [9] — 
are very popular. Single-side- 
band (SSB) demodulation is 
used to receive weather data. 
For this purpose, Dream is set 
to ‘USB’ (upper sideband) as 
shown in Figure 3. To keep 
the signal level as steady 
as possible, you can select 
the ‘Fast’ option under ‘AGC’ 
(automatic gain control). The 
‘Noise Reduction’ option 
appears to distort the signal 
and is not recommended by 
the author. Dream includes 
an audio recording function 
(‘Save Audio’), which is use- 
ful for storing the received 
signals. 

The subjective sound quality 
of the SDRadio demodulation 
software is somewhat bet- 
ter due to its good noise sup- 
pression. It is also operated in 
USB mode for demodulation 
(Figure 4). 

Now the trick is to find the 
right transmitting station and 
configure the signal band- 
width properly. Recorded 
examples of individual sig- 
nals, which are also available 
on the Elektor website, are 
very helpful for this purpose. 
NAVTEX, RTTY, and weather 
fax signals have their own 
characteristic sounds, and 
after a bit of practice you 
will be able to identify them 
clearly. 


Weather data 
decoder software 
The author uses SeaTTY [10] 
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Elektor SDR Tuning 30 kHz ... 30000 kHz, 1 kHz steps 





Figure 2. Elektor SDR tuning software with a broad tuning range. 
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Figure 3. Configuration settings for Dream. 
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Figure 4. Another good option: SDRadio. 


ass | 


for weather data decoding. 
This program (Figure 5) has 
proven to be a good choice for 
this purpose because it pro- 
vides all the necessary func- 
tions in a readily understand- 
able form and is by far the 
easiest to use. 

A few operational settings 
are necessary. Use the ‘Setup’ 
menu to select the appropri- 
ate sound card, such as the 
mini USB sound card. You can 
select the decoding mode in 
the ‘Mode’ menu. Use ‘NAV- 
TEX’ or ‘RTTY’ for weather 
messages in text form, or ‘HF- 
Fax’ for weather fax data. The 
‘Speed’ and ‘Shift’ parameters 
must be configured accord- 
ing to the specifications of 
the weather data transmit- 
ting station. They are stated 
in the header of the transmis- 
sion schedule. For example, if 
a frequency shift of +225 Hz 
is specified, SeaTTY must be 
configured with a ‘Shift’ value 
of 450 Hz. 

The spectrum of the sig- 
nal currently being received 
is shown in the upper part 
of the SeaTTY window. If 
SeaTTY cannot find the two 
peaks on its own, you can use 
the mouse to drag the two 
red lines to the right posi- 
tions. Decoding then starts 
immediately, and the text 
appears in the box below the 
spectrum display. All data 
is logged automatically, and 
it can be retrieved and dis- 
played whenever desired. 
This program costs around 
$ 50 (€ 35) , and it also runs 
under Windows Vista. 

An alternative to SeaTTY 
is JVComm [11], which is 
also widely used. It requires 
the same settings [12] as 
seaTTY, but it is distinctly 
more expensive. 

A freeware option is MMTTY 
[13], but it is limited to RTTY 
reception. A German help file 
is available online [14]. A free- 
ware program for NAVTEX is 
available at [15]. 


Antennas 


As the saying goes, the best 
preamp for a receiver is a 
good antenna. Two types of 
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antenna are suitable for receiving 
marine weather radio signals: long- 
wire antennas and ferrite antennas. 
When a sailor hears the words ‘long- 
wire antenna’, the first thing that 
comes to mind is the aft stay. The 
best reception is obtained with an 
insulated stay, with the signal being 
tapped off using a balun. A balun is 

a wideband, high-frequency trans- 
former, and here it converts the 
characteristic impedance of the 
long-wire antenna to the impedance 
of the coaxial cable over the range 
of 100 kHz to 40 MHz. If the coaxial 
cable were connected directly to the 
aft stay, only around 10% of the sig- 
nal would reach the receiver, with 
the rest being lost in reflections. A 
fully encapsulated version that can 
withstand sea water is available 
from boating accessories specialists. 
For charter sailors, a traditional hori- 
zontal long-wire antenna is far less 
expensive and easier to install. A 10- 
metre length of 0.6-mm enamelled cop- 
per wire is fully adequate, and it can 
be connected to the SDR board either 
directly or via a length of coaxial cable. 
You can string the antenna in the cabin 
along the four edges of the ceiling. The 
best way to secure it is with adhesive 
tape applied to wooden parts, since 
adhesion on other surfaces is quite 
poor due to the high humidity. 

To significantly improve reception, you 
should also use a ground if at all possi- 
ble. The ground is just as important as 
the actual antenna, since it acts asa 
counterpoise to the long-wire antenna. 
The quality of reception is unpredict- 
able without a proper ground. 

There are various ways to create an 
HF ground on a sailboat. If you want 
to know more about this subject, 
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Figure 5. SeaTTY is a proven program for weather data decoding. 


with some efforts the basics can be 
extracted from [16]. 

The metallic parts of a sailboat are 
usually bonded electrically in the inter- 
est of lightning protection. All branch 
circuits, the keel, and usually the neg- 
ative battery terminal of the onboard 
electrical system and the protective 
earth lead of the dockside power sys- 
tem are connected to a common earth 
lead that runs from fore to aft. For this 
reason, the simplest solution is to use 
the earth contact of an onboard elec- 
trical socket as the HF ground termi- 
nal. It should be connected to the SDR 
board by an insulated wire with ade- 
quate cross section (at least 2.5 mm2). 
Here it is important that the boat earth 
is absolutely potential-free in order 
to avoid damaging the receiver. You 
should first check with a multimeter 
to ensure that there is no stray volt- 
age present at the earth terminal. 
The advantages of a ferrite antenna 


relative to a long-wire antenna are 
its compact dimensions and oper- 
ation without a ground connec- 
tion. Antenna construction is rela- 
tively easy, and it is described on 
the Elexs website [17]. Satisfactory 
results can be obtained by winding 
90 turns of 0.2-mm enamelled cop- 
per wire on a ferrite rod. However, 
in practical tests the author always 
obtained better results with a long- 
wire antenna. 

(080685-1) 


Links: 


[1] www.elektor.com/070039 


[2a] http://www.metoffice.gov.uk/weather/ 
marine/guide/radio.html 


[2b] http://www.weather.gov/nwr/listcov. 
htm 


[3] www.nws.noaa.gov/om/marine/rtax. pdt 


[4] www.speed-link. 
com/?¢p=2&cat= 15&pid=2810&paus= 1 


[5] www.ntonyx.com/vac.htm 

[6] www.elektor.com/070389 

[7] www.elektor.com/080685 

[8] http://devel.der-schall.de/downloads.php 
[9] www.sdradio.org 


[10] http://www.dxsoft. 
com/en/products/seatty/ 


[11] www.jvcomm.de 
[12] http://dj4ig.de/wetter.htm 


[13] http://mmhamsoft.amateur-radio.ca/ 
mmity/index.html 


[14] www.janson-soft.de/seminare/dh/uat/ 
mmttydeuhelp. pdf 


[15] www.frisnit.com/navtex/index.php 


[16] www.sy-merger. 
de/AFU/web-content/HF-Erde_V1_0.pdf 


[17] www.elexs.de/iq9.htm 
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NAVTEX 


able, especially at night. 


The Navigational Warnings by Telex (NAVTEX) system is used world- 
wide for the automatic transmission of regional maritime safety infor- 
mation (MSI) using radio teletype with error correction (SITOR-B). The 


NAVTEX is used primarily in the North Sea region, the Mediterranean 
region, the coastal regions of Japan, and along all coasts of the North 
American continent. The transmission times are coordinated (time 
sharing) to avoid interference between transmitters operating on the 
same frequency. In addition, the transmitter power is adapted to the 
signal propagation conditions, since the transmission range in this fre- 
quency band (lower edge of the medium-wave band) can be consider- 


main transmission frequency for broadcasts in English is 518 kHz, with | ae 
a second frequency at 490 kHz available for local languages. The Y fie, amm t 
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Temperature measurement 
with the ATM18 and a 1-wire bus 


Wolfgang Rudolph, Burkhard Kainka and Udo Jürß (Germany) 


We all know what ‘cold’ means, but cold is not a physical quantity. If we define it as the absence of 


heat, we're heading in the right direction in terms of physics. Like darkness, cold is not ‘real’, but in 


subjective human terms we can certainly talk about cold, dark nights. A more objective approach is to 


measure the temperature, which is what we have in mind this time with our ATM18 system. 


Where does the concept of temperature 
come from? The path from the subjec- 
tive sense of temperature to an objec- 
tive, measurable physical quantity was 
not easy. The vibration of atoms and 
molecules, which becomes stronger as 
the temperature increases, exceeded 
our mental grasp for a long time. 


However, around 1700 (the exact 
date is not known) Isaac Newton 
had already discovered the princi- 
ple of heat. He devised a temperature 
scale with its zero point at the tem- 
perature of freezing water. One degree 
on the Newton scale corresponds to 
3.03 degrees Celsius. Other tempera- 
ture scales followed quickly, all with 
different sizes of degrees. The Romer 
scale (1 °Ro = 1.9 °C) was defined in 
1701, followed by the Fahrenheit scale 
(1 °F = 0.56 °C) in 1714 and the Réau- 
mur scale in 1730 (1 °Re = 1.25 °C). The 
Celsius scale was defined in 1742, and 
the Kelvin scale, in 1848. The degree 
spacing of the Kelvin scale is the same 
as that of the Celsius scale. 


The various temperature scales differ 
not only in the size of their degrees, but 
also in their reference points. The Fahr- 
enheit scale, which still predominates 
in the USA, is especially strange: the 
zero point (0 °F = —18.3 °C) is defined 
by a mixture of ice, water and sea 
salt, while the body temperature of a 
healthy person (35.6 °C) serves as the 
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upper reference point. To make things 
even more complicated, there are only 
96 graduations between the two refer- 
ence points instead of 100. This means 
that a person with a body temperature 
of 100 °F has a slight fever (37.8 °C). 
When the metric system of units (the 
SI system, which stands for Systeme 
International d’Unités) was intro- 
duced in 1960, it included only one 
unit for temperature — the Kelvin — with 
degrees Celsius as a derived unit. The 
degrees of both scales are the same, 
but the zero point of the Kelvin scale 
is absolute zero, which corresponds to 
—273.15 °C. Naturally, this means that 
0 °C = 273.15 K. This interesting topic 
is discussed in great detail in a very 
informative article at [1]. 

Only quantities that can be measured 
can be put to use for other purposes. 
In the old days, when we (as elec- 
tronics enthusisasts or professionals) 
wanted to know how warm or cold it 
was, we had a relatively limited selec- 
tion of inexpensive temperature sen- 
sors to choose from. The most com- 
monly used sensors were thermistors, 
which are resistors whose resistance 
depends on their temperature — but not 
linearly. You could connect a milliam- 
pere meter in series with a thermistor 
and read the temperature from a home- 
made scale. For any further processing, 
the non-linear characteristic had to be 
linearised. Instead of making complex 
calculations, people often used tables 


of resistance versus temperature for 
this purpose. It was sometimes neces- 
sary to generate your own table. 
However, those days are long gone. 
Today sensors with integrated signal 
conditioning, which output the meas- 
ured temperature in digital form and 
do not require any additional circuitry, 
are available at low prices. The sen- 
sors used in the project described in 
this article even draw their operating 
power from the data line, which means 
they can be used with what is called a 
‘one-wire network’. 


The one-wire hoax 


The one-wire technology was devel- 
oped by Dallas Semiconductor, which 
now belongs to Maxim. This network 
technology uses a twisted-pair ‘bus’ 
for all of its communication. Here ‘one 
wire’ is clever marketing ploy that is 
only true if you don’t count the ground 
wire. Naturally, the bus needs a ground 
line as well as a data line in order to 
work properly. What makes this tech- 
nology attractive is that you can con- 
nect many devices in parallel to this 
two-wire bus. 


The data line must be pulled to +5 V 
by a pull-up resistor. This represents 
the ‘high’ level. To write a logic 1, the 
bus is pulled to the Low level (ground) 
for less than 15 us. To transmit a logic 
zero, the bus is also pulled Low, but in 
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this case for at least 60 Us. To initiate a 
communication session, the bus mas- 
ter (in our case the ATmega) performs 
a bus reset by pulling the bus Low 
for longer than 480 us. It then waits 
for responses from the slave devices, 
in our case the temperature sensors, 
which issue an extended Low pulse. 

If the master wants to communicate 
with a particular slave, it sends the 
address of the slave device and initi- 
ates a handshake. After the slave has 
responded, the master sends com- 
mands (which may be device-specific) 
and waits for responses. Every compo- 
nent with a 1-wire port has a unique 
64-bit serial number. These numbers 
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are assigned to the components when 
they are manufactured, and they can- 
not be changed. 


There are various types of sensors on 
the market. We chose the DS1820 and 
its successor, the DS18S20, which is 
functionally equivalent and pin-com- 
patible with the DS1820 and also has 
the type designation ‘DS81820’ printed 
on the package. The specifications of 
this device are listed in Table 1, and 
its block diagram is shown in Figure 1. 
The pin assignments of the two pack- 
age options are shown in Figure 2. 

The maximum achievable bus length 
depends on the value of the pull-up 


DS18S20 


MEMORY CONTROL 
OGIC 





resistor connected between the data 
line (DQ) and the positive supply volt- 
age Voc (+5 V). Based on practical 
experience, up to 80 m (250 ft) can be 
regarded as reliable. Longer values 
are possible, but external noise on the 
bus increases with the length of the 
network. The maximum cable length 
can be increased by connecting a sec- 
ond pull-up resistor (with a value in 
the range of 1.5 to 10 KQ) between 
the data line and Veç, but this slightly 
degrades the measurement accuracy 
due to increased internal heating of 
the sensors. If the system is operated 
using a three-wire bus, the supply 
voltage should be decoupled at each 


Table 1 


DS18S20 features 


@ 64-bit serial ID code in ROM 


@ 9-bit resolution (0.5 degree) 


TEMPERATURE SENSOR 
ALARM HIGH TRIGGER (Tj) 
REGISTER (EEPROM) 
ALARM LOW TRIGGER (T,) 
REGISTER (EEPROM) 

8-BIT CRC GENERATOR 
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from —10 to +85 °C 


INTERNAL Vip 64-BIT ROM 


@ Temperature measuring range 
-55 to +125 °C 


@ Package: 3-pin TO-92 or 8-pin SO 
@ Operating voltage: 3.0-5.5 V 
@ Current drain: 1 mA (standby: 750 nA) 


SCRATCHPAD 


i AND 
1-Wire PORT 
Cpp 
vy 
/N 
POWER- 
SUPPLY 


SENSE 


@ Temperature conversion time: 750 ms 





@ Drift: +0.2 degree 





Figure 1. Block diagram from the DS18S20 data sheet. 
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(DS18S20Z) 
SO (150 mils) 


(BOTTOM VIEW) 
FN lee 080641 - 12 


Figure 2. Pin assignments of the TO-92 and SMD versions. 


sensor by a 100-nF ceramic capacitor. 
With this arrangement, we managed 
to implement bus lengths up to 300 m 
(1000 ft) in our experiments. 


Simple, fast construction 


Putting a system together is very easy 
and only requires connecting the LC 
display and the twisted-pair bus line 
with the sensors, including the 4.7-kQ 
pull-up resistor (see Figure 3). For ref- 
erence, the wiring is also described in 
the source code of the ATM18 DS1820 _ 
Network project. The LCD module 
is connected to PB1 (clock) and PB2 
(data). The Vpp and GND leads of the 
DS1820 are connected to the GND of 
the ATM18 test board, while the data 
lead is connected to PD5. This pin 
assignment can be altered by editing 
application.h. It is essential to connect 
the 4.7-KQ pull-up resistor to Voc. Oth- 
erwise the system won't work, even 
with an external power supply. 

When everything has been connected 
properly and the right software [2] has 


12 OOO! CLLK 
2x DS1820 O a“ 
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Figure 3. Wiring diagram showing the temperature sensors on the two-wire bus, the pull-up resistor and the LC display. 


been downloaded to the flash memory 
of the microcontroller, you’re ready to 
go. The received data is transmitted 
via the serial interface at 38,400 baud, 
and the status of the network is shown 
on the LC display (see Figure 4). The 
BASCOM software does not drive the 
display, but only sends the data to the 
PC via the serial link. 


Power supply 


If you include the ground wire in the 
count, the one-wire bus is a two-wire 
bus. However, the DS1820 has three 
leads, and you have to decide what to 
do with the third lead (Vp). Many Dal- 
las chips actually need only two leads 
(data and ground), with the data lead 
also serving as the power lead. This 
is also true for the DS1820. However, 
there are certain situations in which 
the DS1820 sensor needs more current 
than it can obtain with the usual pull- 
up resistor value of 4.7 kQ. The options 
here are to connect Vpp to +5 V, which 
means using a three-wire bus, or to 
make a low-impedance connection 


between the DO line and Voc in certain 
situations. If you look on the Web for 
sample programs for the DS1820, you 
may run into problems for exactly this 
reason. The author may have wired 
Vpp Separately but not mentioned this 
in the software. If you use only two 
wires, you will be left wondering why 
your system doesn’t work. 


The two power supply options are 
shown on the data sheet. You can either 
use Vpp (Figure 5) or transmit the sup- 
ply voltage via the data bus (Figure 6). 
The second option has the advantage 
that, as already mentioned, you only 
need two wires to connect the sensors 
to the bus. The FET that is necessary 
for connecting the bus to the supply 
voltage of the microcontroller is already 
present in the ATmega88. All that has 
to be done is to configure the appro- 
priate I/O pin as an output and set it 
to the ‘high’ state. There are two situ- 
ations where this is necessary. When 
a temperature measurement must be 
performed, the IC needs a bit of extra 
power for 750 ms, and when data must 
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Figure 4. Find and seek. 
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be written to the internal EEPROM, it 
needs more juice for 10 ms. 

You can connect a single sensor or 
several sensors. The software for the 
arrangement with only one sensor is 
different from the software for a bus 
system. It is usually necessary to first 
identify all the sensor ICs on the one- 
wire bus so they can be addressed 
individually. For systems with only 
one sensor IC, Dallas has generated a 
simplified protocol that works without 
addressing. The first example in BAS- 
COM is designed to use this simplified 
protocol. 


One wire, one chip 


BASCOM code supports the one-wire 
bus with special commands. This 
means that you don’t have to do very 
much; all you really have to do is to 
decide which port pin to use for the 
bus. You can select any desired pin, 
and here we decided to use port D.5 
(Config 1wire = Portd.5) 

Every action is initiated by a bus reset 
(1wreset). After this you can write 
and read data. All of the details are 
described in the data sheet [3]. In order 
to communicate with a single IC, you 
use the SKIP ROM command [CCh]. 
This causes the IC to regard itself as 
addressed, even though its address 
has not been mentioned. This is simi- 
lar to the situation in a tiny village with 
only one inhabitant: no house number 
is necessary. 

Next comes the temperature meas- 
urement command CONVERT T [44h]. 
Immediately after this, the power sup- 
ply must be switched on. Although 
the bus is already at a ‘high’ level in 
the idle state, this puts it in the low- 
impedance ‘high’ state (Ddrd.5 = 1). 
The maximum time necessary for mak- 
ing a measurement is 750 ms. To be 
on the safe side, you can always allo- 
cate 800 ms for this state. After this 
the port pin must again be configured 
as an input (Ddrd.5 = 0). The DS1820 
now knows the temperature, but it still 
has to be read out. To do this, your first 
send a Bus Reset and then the Read 
Scratchpad command [BEh]. Up to 
eight bytes can then be read from 
the IC. The meaning of these bytes is 
described in the data sheet (see Fig- 
ure 7). The temperature data is located 
in two bytes, but the data in the high 
byte only distinguishes between posi- 
tive (00) and negative (FF) tempera- 
tures. If you want to read the temper- 
ature with higher resolution, you must 
evaluate even more bytes. However, 
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Figure 5. Power supply via Vpp. 


1-Wire BUS 





this is not done in the first example. 
For your initial testing in the lab, you 
can assume that the temperature will 
be positive. This means you only have 
to read one byte, which contains the 
temperature measurement in units of 
0.5 degree. Simply divide the value of 
the byte by 2 to obtain integer degrees. 
Listing 1 shows a very simple program 
that sends the temperature in degrees, 
without any digits after the decimal 
point, to the PC at 38,400 baud. 


If you see a constant temperature of 
85 degrees during your experiments, 
there is something wrong with the 
temperature conversion or the power 
supply, since this is the default set- 
ting after power-on before any meas- 
urement is made. 


Naturally, you can do more with the 
temperature measurements than just 
display them. Listing 2 shows a sim- 
ple threshold switch with two levels. 
Output D2 switches when the tem- 
perature reaches 25 degrees, and out- 
put D3 switches when it reaches 30 
degrees. If you can’t think of any better 
use for this, you can always use it with 
two LEDs as a party gag. Have your 
guests hold the sensor between two 
fingers. With this simple instrument, 
you can classify them into three types: 
hot, lukewarm, and zombie. 


DS18S20 


GND DQ Vo 
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Listing 1. 


Temperature measurement 
with one sensor 


‘BASCOM-AVR 
‘DS18S20 1 wire PD.5 


Sregfile = “m88def.dat” 
Scrystal = 16000000 
Sbaud = 38400 


Config lwire = Portd.5 


Dim Roml As Integer 
Dim Temp As Integer 


Wait 1 
Ddrb.3 = 1 
Do 

lwreset 


lwwrite &HCC 
lwwrite &H44 


Ddrd.5 = 1 
Waitms 800 
Ddrd.5 = 0 
lwreset 


lwwrite &HCC 
lwwrite &HBE 
Romi = lwread(1) 
lwreset 
Temp = Romi / 2 
Print Temp 
Waitms 100 

Loop 


| Ddrd.2 = 1 i 


bekann a a cy a a M M ce ee 
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Listing 2 


SCRATCHPAD 
(POWER-UP STATE) 


Byte 0 | Temperature LSB aw 


Dual-threshold switch 


If Temp > 24 Then 
Portd.2 = 1 
Else 


Portd.2 = 0 i Byte 4 | Reserved (FFh) 

i a i Byte 5 | Reserved (FFh) 

! If Temp > 29 Then ! 

| Byte 6 | COUNT REMAIN (0Ch) 


Portd.3 = 1 





Else Byte 7 | COUNT PER °C (10h) 
ee * Power-up state depends on value(s) stored in EEPROM. 080641 - 16 
Several DS1820s on a single bus Prud R contens: 


Every one-wire IC has a 48-bit number, 
and there are no two ICs with the same 
number (at least not from Dallas). You 
obtain this number by reading and 


Listing 3 


Dim Temp As Single 
Dim Tempdif As Single 


i , Using two sensors Dim Id1(8) As Byte 
storing a total of eight bytes. You can Dim Id2(8) As Byte 
then use it on the bus as an address 04FF49801080033 Dii. T aa Tobeger 
for communicating selectively with a 106F0099010800B3 
particular IC. The ICs do not even have 
to be the same type, since the type of ‘Atm18 DS1820 Bus Id1 (1) = lwsearchfirst () 
each one-wire IC is included in the Id2(1) = lwsearchnext () 
address (see Figure 8). sregfile = “m88def.dat” 


Scrystal = 16000000 


To start with, you can query how ! ! 
ı Baud = 38400 


many devices are present on the bus 
(1wirecount). The Dallas bus protocol 
specifies that all ICs report their ID 
number at the beginning. BASCOM 
use two functions, 1wsearchfirst() and 


I = 1lwirecount () 
Print I 


\kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


` BASCOM-AVR 


‘DS18S20 1 wire PD.5 For I = 1 To 8 


Print Hex(id1(i))j; 


lwsearchnext(), to query them. An Sregfile = “m88def.dat” ae 
array of eight bytes must be allocated Scrystal = 16000000 Print 
for each ID code: Sbaud = 38400 Por I = 1 Ta 8 
Config lwire = Portd.5 Print Hex(ida(1)); 
; i Next 
Dim Id1(8) As Byte, Dim Id2 (8) Sant Ponta Bares en 


AS ia eee eee ee ee eee eee eee eee eee eee 


The example in Listing 3 is limited to 
two devices on the bus. Simply to sat- 
isfy our curiosity, we displayed the two 
IDs on the PC. They both start with 


peer eee ee ee ee ee ee ee ee ee ee ee ee eB eB ee eB ee Be Be ee ee ee eB Be ee ee ee ee ee eB eB eB ee eB eB ee ee ee ee ee ee eB eB ee ee ee ee He AKG 


Listing 4 


Print Temp; 


i 7 : . i . 1 P 7 t ~“ Ws 
10’, which is the ‘family code’ of the i i ns 
Measuring with two sensors 

DS1820. 
The temperature measurement rou- Wait 1 lwresct 
tine in Listing 4 first uses the non- Ddrd.2 = 1 lwwrite &H55 
addressed mode to trigger a new Ddrb.3 = 1 For I = 1 To 8 
conversion. This means that all of Do lwwrite Id2(1) 
the temperature measurement ICs on Pen Next I 

, lwwrite &HCC 
the bus receive the same command 
and make their measurements at the iwwrite griid 
ing interval has expired, the ICs are Waitms 800 Rom(1) = 1wread (8) 


same time. After the 800-ms measur- ' Ddrd.5 = 1 lwwrite &HBE ! 


addressed individually and read out. Ddrd.5 = 0 Temp = Rom(1) / 2 
Addressing is performed by send- n : 
, wrese 
ing the MATCH ROM command [Soh] ee eee Tempdif = 16 - Rom(7) 
followed by the eight ID bytes. This Tempdif = Tempdif / 16 
can be done by sending the individ- For I = 1 To 8 Tempdif = 0.25 * Tempdif 
ual bytes in a loop, or all at once with lwwrite Id1(i) Teme = Temp + Tenpdit 
1wwrite Id2(1), 8. Sending an address NERE 1 brink Busine (en NH HH) 
causes a particular IC to be selected. a pees ee Taiere T0Ù 7 P’ 

è . om = wrea 
Only this IC will respond to the readout Temp ont) 7 2 coe 


command. You can now read out a sin-  ([___________________.___ ee! 
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gle byte, or all eight bytes at once in 
order to increase the temperature reso- 
lution (Rom(1) = 1wread(8)). 

You can increase the temperature reso- 
lution by evaluating the seventh byte 
(COUNT REMAIN) of the set of read 
bytes. It contains a value in the range 
of 1 to 16, which must be interpreted 
as sixteenths of a degree. However, 
you must be careful here because the 
least significant bit of the low byte 
of the ‘regular’ temperature reading 
(0.5 degree) is the same as the most 
significant bit of the Count Remain 
register. This means that you must first 
round to whole degrees and then add 
the sixteenths count. 

The best possible resolution is thus 
0.06 degree, so the result is displayed 
with two digits after the decimal 
point. Naturally, the final digit should 
be treated with caution, since you 
should always make a clear distinc- 
tion between accuracy and resolution. 
The actual accuracy is approximately 
0.5 °C in the range from —55 °C to + 
85 °C. However, the enhanced resolu- 
tion makes it easier to recognise very 
small temperature changes. If you hold 


8-BIT CRC 48-BIT SERIAL NUMBER 8-BIT FAMILY CODE (10h) 


MSB LSB MSB 


LSB MSB LSB 
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Figure 8. Chip address. 
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The ATM18 project at Computer:club2 


ATM 18 is a joint project of Elektor and Computer:club2 (www.cczwei.de) in collaboration with 
Udo Jürsz, Chief Designer of www.microdrones.de. The latest developments and applications 
of the Elektor ATM18 are presented by Computer:club2 member Wolfgang Rudolph in the 
CC2-tv programme broadcast on the German NRW-TV channel. The IR distance sensor and 
ATM18-AVR board combination described here was featured in instalment 25 of CC2-tv. 


CC2-tv is broadcast live by NRW-TV via the cable television network in North Rhine-Westphalia 
and as a LiveStream programme via the Internet (www.nrw.tv/home/cc2). CC2-tv is also 
available as a podcast from www.cczwei.de and — a few days later — from sevenload.de. 
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two sensors in close thermal contact 
and compare their displayed readings, 
you will see that the difference is usu- 
ally less than 0.1 °C. 

(080641-1) 
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LaS FROM USB TO 12C 


USB-I7C Bridge 


‘Easyspeak |-square-C’ using 1-Wire 


Fons Janssen (The Netherlands), Maxim Benelux 


Modern computers no longer come with parallel or serial ports fitted. Although these ports see declining 


use in practice, to designers, a portless PC is a nuisance. To solve at least a part of the problem, we 


present an interface for the I2C bus for connection to an USB connection on your PC. It works a treat 


when used in the LabVIEW environment. 


Quick project specs 
@ Simple and compact design 


@ Compatible with Windows XP and Vista 


@ Compatible with LabVIEW 7 or newer 
(must have .net support) 


@ Works on USB-power 


@ All ICs can be sampled at Maxim 


Sometimes you simply want your PC 
to communicate directly to hardware 
via an I2C interface. There are several 
options to do this, but not all of them 
offer the right features. For instance, 
there is a way to use the parallel port 
to emulate an I?C master (see [1]). A 
problem with this solution is that new 
PCs often lack a parallel port (a.k.a. 
‘LPT’, ‘Centronics’ or ‘printer’). Another 
problem is that contemporary Windows 
releases like XP and Vista do not allow 
easy access to the old serial or paral- 
lel ports, making them cumbersome to 
use if they are fitted in the first place. 


Enter USB 


A hopefully future-proof approach 
would be to use the USB port. How- 
ever, this requires a complex driver and 
most probably a microcontroller, which 
requires the appropriate firmware. This 
is not something you can build in an 
afternoon. There are numerous commer- 
cial versions that don’t come cheap. 

The following solution can be built 
quickly and offers the possibility to 
use it in a variety of programming lan- 
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guages (LabVIEW, Visual Basic, etc.). 
This solution employs 1-Wire technol- 
ogy from Maxim Integrated Products 
(or ‘Maxim’ for short). 


Hardware 


The hardware setup is shown in Fig- 
ure 1. The circuit connects to the PC 
via USB connector K1. The circuit sup- 
ply voltage arriving via the USB is fil- 
tered by L1 and L2. It would probably 
work without these inductors, but I like 
to firmly rule out any potential prob- 


lems. The USB data lines D+ and D- 
are connected to IC2; the DS2490S+, 
via R2 and R3. This IC contains a com- 
plete USB slave and takes care of the 
USB enumeration process. R1 pulls up 
the D+ line to indicate that IC2 is a 
full-speed (i.e. 12 Mbit/s) USB slave. 

IC2 also contains a 1-Wire master, so 
that any 1-Wire slave device can be 
addressed from the PC. The only 1-Wire 
slave in the circuit is IC3 (a DS2413 
from Maxim), which is an I/O Extender 
offering two bidirectional open-drain 
ports (PIOA & PIOB). R4 and R5 are 


DS2413P 
GND GND 
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Figure 1. This circuit provides an 12C interface to a computer’s USB port. 
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pull-up resistors for these two open- 
drain ports. This is exactly the right 
amount of hardware needed to create 
an I2C master. There is a PCB layout 
(see Figure 2) that can be downloaded 
free from the Elektor website [2] for 
home etching and drilling. Alterna- 
tively, readers can order a ready-made 
PCB from ThePCBShop.com [3]. 


Software 


On microcontrollers that do not have 
a hardware I2C master, ‘bit banging’ 
is a proven method for implementing 
a software I2C master. With this very 
same technique, a software I2C master 
can be created on this platform. 


The software needs to control the logic 
levels of the two pins to generate the 
I2C signals. For instance, to create a 
so-called start condition, SCL needs to 
be High, while SDA drops from High 
to Low. To create this condition, first 
both SCL (PIOA) and SDA (PIOB) need 
to be High, after which SDA is pulled 
Low. So, if the software has the ability 
to control PIOA and PIOB, the I2C mas- 
ter is a matter of software. 


To change the PIO outputs, the part 
needs to be addressed first (ROM 
functions). In this case, there is only 
one 1-Wire slave present, so the skip 
ROM command (‘CC’; for a full list of 
1-Wire commands for various devices 
see [4]) can be used to skip the com- 
plex addressing procedure. Then the 
‘5A’ command is sent to allow writing 
to the PIO output latches (the com- 
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Figure 2. The component layout is very orderly. The PCB artwork can be downloaded free of charge from www.elektor.com. 


mand set for the DS2413 and its PIO 
function flow chart can be found in its 
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COMPONENT LIST 


Resistors 

(all 0805 shape) 
RI = 1kQ5 
R2,R3 = 27Q 
R4,R5 = 4kQ7 


C1 = 1uF (0805) 

C2 = 4uF7 (0805) 

C3 = 100nF (0805) 
C4-C7 = 33pF (0603) 


Inductors 
L1,L2 = BLM21PG221SN1J (Murata) (220Q 


ı Capacitors 
‘at 100 MHz) 
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datasheet [5]). 
There is an 8-bit register of which the 


Semiconductors 

IC1 = MAX8881EUT33+ (Maxim Integrated 
Products) 

IC2 = D$2490S+ (Maxim Integrated 
Products) 

IC3 = D$2413P+ (Maxim Integrated 
Products) 


Miscellaneous 

K1 = USB connector, PCB mount, type B 

K2 = RJ-11 connector, PCB mount 

X1 = 12MHz quartz crystal 

PCB, ref. 080655-1, from www.ThePCB- 
Shop.com 
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two LSBs are connected to 
PIOA and PIOB (the other 
six bits are ‘don’t care’). To 
change the logic state, the 
new data is sent twice: once 
normal and once inverted. 
The DS2413 confirms error 
free reception by returning 
‘AA’ to the master and con- 
cludes by sending the new 
output state as well. 


Now the whole sequence 
can start over again, or it 
can be aborted by a reset 
from the 1-Wire master. 


FROM USB TO 12C 


Table 1. Generating an 1?C start command 


Master Mode | Data | Comments | 





ple only works if the 1-wire 
driver is installed with .NET 
support. Also the Microsoft 
.NET framework and Visual 
J# redistributable package 
need to be installed first 
(see [6] for details). 


Virtual Instruments 


The LabVIEW Virtual 
Instrument (VI) ‘I2C Initial- 
ize’ (Figure 3 displays the 
block diagram) initializes 
the DS2490 and gives Lab- 
VIEW exclusive access to 


Get Default Adapter 


getDefaultAdapter in 
[eal : 


Z 
2! 


putByte 
bykevalue 


11111111 
11111101 


putByte 
bykevalue 


Get exclusive access 


a a 
beginExclusive + 
' blocking 


SCL = High, 504 = 5D in 


A w OSPortadapter BO R OSPortAdapter PEJA = OSPortAdapter BJE "+ OSPortAdapter 5 
putByte getByte r getByte ' 


Reset the 1-wire met Skip ROM 


Bw DSPortAdapter BJP « 


reset j 


inverted byte get "44" byte From D52413 


bykevalue 


inverted byte get "44" byte From D52413 


bybteValue 


putByte g 
bybeValue 


etDef aulk4dapter 


PIO access write on 052413 


F "+ DSPortådapter F 


putByte 
bykevalue 


select 50A (PIOB 


putByte getByte ' getByte 0 


getDefaulkadapter out 


[£] 
=r 


io] 


read ouput 





Figure 4. The VI ‘I2C clock’ toggles SCL from Low to High. SDA can be set or reset for ‘I2C write’ actions and read for ‘IC read’ actions. 


Thus, a total of four bytes is trans- 
ferred for each output change (if the 
Skip ROM and 5A command are not 
taken into account). 

To generate the I2C start command, 
the sequence shown in Table 1 needs 
to be executed. For other events, simi- 
lar sequences apply (stop, send byte, 
acknowledge, etc.). 


net 


Maxim offers software drivers for the 
DS2490 (DS9490) and also a 1-Wire 
Software Development Kit (SDK) for 
Windows. This SDK offers support for 
Microsoft’s ._NET platform. As an exam- 
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ple we will show how an I2C master 
can be implemented in LabVIEW, 
using its .NET support. This exam- 





Figure 5. Example of how fo read a register. 


the 1-Wire net. This is to prevent other 
applications from accessing the 1-Wire 
net. After this, a 1-Wire reset is issued 
followed by a skip command (CC) and 
concluded by a PIO write command 
(5A). 


Now the DS2413 is ready to accept 
data for the PIOs. The VI ‘I2C clock’ 
(Figure 4) toggles the SCL line from 
Low to High; SDA can be set High or 
Low and the VI returns the SDA state. 
A complete byte can be written by call- 
ing this function eight times in a row 
(once for every bit transmitted). If the 
slave is returning data, SDA is pulled 
High by the master. The slave can pull 
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SDA Low in case it wants to 
transmit a ‘0’ (this is okay, since 
PIOB is an open-drain terminal). 
Since the DS2413 automatically 
returns the updated output 
state, no special read action 
is required (see VIs ‘Send I2C 
byte’ and ‘Get I2C byte’ in the 
supplementary software down- 
load [2]). 


The VIs ‘I2C start’, ‘I2C stop’, 
and ‘I2C acknowledge’ — also 
in the supplementary down- 
load — use the same structure 
to generate the appropriate 
SDA and SCL signals. By com- 
bining these VIs, a complete 
IC read or write session can be 
programmed. 


In Figure 5 we see an example of a 
communication session, where Regis- 
ter 0 of a DS1337 (I2C Real Time Clock) 
is read. The DS1337 answers with 
0x39, which is the content of the reg- 
ister that counts the seconds. The reg- 
ister address is set to 0x00, the slave 
address to OxDO, and the number of 


PS] 17101000 ry coo00000 F1Sr] 1107000 [1A 0011 1001 AP} 





Figure 6. Read register 0 of the DS1337. 
S=start, A=acknowledge, Sr=repeated start, and P=Stop. 


Traffic from master to slave is shaded; from slave to master, white. 


bytes to read is set to 1. With these 
settings, the scope image in Figure 6 
shows the signals generated by the 
circuit. 


Because the overhead is quite big, the 
rate at which the signals are gener- 
ated is severely limited (of the order 


NEWS & NEW PRODUCTS (ier at) 


Multiprocessing, magnetism and the milky way 


3L recently announced that a 

new broad-band spectroscopic 
data acquisition system has been 
built and deployed for the 26-m 
radiotelescope of the Dominion 
Radio Astrophysical Observatory 
(DRAO) in Penticton, Canada. De- 
signed using 3L’s Diamond multi- 
processor tool-suite and based on 
multiprocessing hardware from 
Sundance, the high sensitivity 
system developed at DRAO has 
an instantaneous bandwidth of 
500 MHz and a spectral resolu- 
tion of 2048 channels. The phase 
relation of the two input signals is 
measured in real-time and using 
3L Diamond, the instrument de- 
sign was completed in only 18 
months, allowing scientists to de- 
ploy the data acquisition system 
earlier than would have otherwise 
been possible. 


Radio astronomers in Penticton are 
using the instrument to investigate 
the magnetic field in the interstellar 
medium of our Galaxy. The large 
bandwidth along with spectral ca- 
pabilities enabled by multiproces- 
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of 20 bits/s). However, the solu- 
tion is quite functional. The VIs 
that are used in the figures can 
be downloaded freely from Ele- 
ktor’s website [2]. Samples of 
all the ICs mentioned in this 
article are available using Max- 
im’s sampling service for design 
engineers and students. It 
should be noted that the DS2490 
is not recommended for new 
designs, but samples will still 
be available for a while. 

(080655-1) 


Internet Links 


[1] www.maxim-ic.com/appnotes.cfm/ 
an_pk/3230 


[2] www.elektor.com/080655 
[3] www.thepcbshop.com 
[4] http://owfs.sourceforge.net/family. html 


[5] http://datasheets.maxim-ic.com/en/ds/ 
DS2413.pdf 


[6] hitp://pdfserv.maxim-ic.com/en/an/ 
AN155.pdf, page 16-17. 


sing is allowing them to measure 
the direction and field strength of 
the magnetic field of the Milky Way. 
Based on the NRC system, DRAO 
astronomers are now leading a 
project to utilize this method with 
other radiotelescopes around the 
globe including the 100-m Eftels- 
berg telescope in Germany and the 
64-m telescope at the Parkes Ob- 
servatory in Australia. 


The NRC design was completed 
using 3L’s Diamond multiproces- 
sor tool-suite with the hard- 

ware consisting of a Sundance 
SMT310Q quad site carrier card 
populated with four daughter mo- 
dules hosted on TIM (Texas Instru- 
ments Module) sites. A C series 

TI DSP mounted on the SMT395, 
two large Xilinx Virtex FPGAs on 
the SMT398 and a Dual Chan- 
nel 1-GHz, 8-bit ADC on the 
SMT391. The ADC samples two 
input channels at 1 GHz which 
are then sent to the FPGAs for 
Fast Fourier Transform. 


www.3L.com 
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C Sharp 


Part 2 


PC programs using .NET and C# 


Veikko Krypczyk (Germany!) 


The .NET Framework relieves PC programmers of considerable effort and doesn’t cost 


a penny. The first part of this series provided a short introduction to C#, the main .NET 


language. This time we present a fully developed graphics application to demonstrate the 


techniques of object-oriented programming. 


There’s one basic rule in .NET: everything’s an Object! 
That's the fundamental difference from classic program- 
ming, in which data is separated from functions (which 
use and deploy data). By comparison, in object-oriented 
programming data and functions form self-contained 
units—called Objects. All Objects used in a program 

are arranged in Classes that specify which data can 

be included in an Object and which functions can be 
deployed in it. Let’s take a simple example: a person pos- 
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! Listing 1. The Class ‘Person’ 


! class Person 
E 
// Characteristics 
float Size; 
string Place of Birth; 
int Age; 
// Methods 
public void Sleeping () 
{ 
// the code for Sleeping 
// thus does nothing! 


} 


public void Eating() 


// relevant code 


} 


public void Learning () 


{ 


// relevant code 


' // create two objects in the Class Person 
| Person sample man = new Person (); 
' Person sample woman = new Person () ; 
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sesses the Characteristics ‘size’ (a floating point number), 
‘place of birth’ (a character string) and ‘age’ (an integer). 
We can also attribute to this person a range of activities 
that are called Methods here. These, for example, could 
include the Methods ‘Sleeping’, ‘Eating’ and ‘Learning’. 
In our program we could define a Class by the name of 
‘Person’. 


A concrete Object arises when we form an Instance from 
a Class (by means of the keyword ‘new’). Using the Class 
‘Person’ we can create as many Instances as we wish. All 
these Objects then make use of the above-mentioned Char- 
acteristics and Methods. A sample implementation of a 
Class ‘Person’ in C# and the creation of two Instances are 
shown in Listing 1. 


Public and private 


The Characteristics and Methods of a Class can be defined 
in a way to make them visible for Objects of other Classes. 
We can also prevent this happening. 


The two extreme cases here are: 


@ Private: the Characteristic or Method is visible only 
within the Class. 


@ Public: the Characteristic or Method is visible for all 
other Objects. 


Taking Variables as an example, these are used only for 
internal calculations within a Method and are therefore 
defined as a private Characteristic. If reference is also 
to be made externally to a Characteristic of an Object, 
then this must be flagged as public. For instance, for the 
Class ‘Person’ it might make sense to define the Charac- 
teristic ‘Age’ as public, to enable other Objects to access 
the person's Age. 


elektor - 3/2009 


A particular advantage of object-oriented programming is 
its ability to ‘inherit’ data. A Class can be derived from 
another Class and in the process it then inherits all char- 
acteristics and capabilities of the parent Class. Taking an 
example, from the Class ‘Person’ we could derive the Sub- 
classes ‘Student’ and ‘Teacher’. Both Subclasses will then 
‘automatically’ possess the same resources at their disposal 
as the Characteristic ‘Age’ or the Method ‘Sleeping’ do. 
Specific Characteristics can also be added individually to 
the derived Classes. For example we could add the Charac- 
teristic ‘Grade point average’ to the Class ‘Student’ (alone) 
and the Characteristic ‘Salary’ only to the Class ‘Teacher’. 
It goes without saying that it is also possible to create Sub- 
classes of .NET Base Classes, for example to create varia- 
tions of top-level elements and much more. The ‘inheritance’ 
feature means that comprehensive Class hierarchies can be 
set up and we'll be demonstrating a tangible example in 
the next section. 


As well as these Characteristics and Methods, a Class can 
also possess Class Events. These Events can be initiated 
while a program is running by the Objects in the Class. If 
the user clicks on a button for example, the event ‘Click’ will 
be triggered for the Buttons. In the definition of Classes we 
need to post some source code for each Event of this kind, 
which sets out the desired reaction. In this way these Events 
provide the foundations of the user interactivity required. 


2-D graphical programming 

Now let's turn to an interesting practical example, specifi- 
cally vector graphics programming in two dimensions. You 
can find the source code on this article’s Web page [1]. 
If you have already installed Visual C# 2008 Express-Edi- 
tion (see Part 1 of this series) you can get the whole project 
up and running with just a double mouse clicks on the file 
name .csproj-Datei in the Development Environment. 
Vector graphics are assembled from individual drawing 
objects, which in turn are composed of a defined number 
of points linked together by straight lines or parts of a cir- 
cle. So what do we need to do to define these drawing 
objects as Objects in our program? We can start by imple- 
menting a way of drawing quite simple objects, such as 
straight lines. Afterwards we can derive Program Objects 
representing more complex constructions from (drawing) 
objects created in a more simple fashion. This ensures the 
program can be expanded without difficulty, which is an 
important point. 


Two significant elements determine program structure: 


@ The Class ‘Grafic’, responsible for graphics output and 
the management of the drawing objects. This Class is set 
out in the file Grafic.cs. 


@ Classes (hierarchy) of the drawing objects. These are 
packaged in the file Objects.cs (see Figure 1). 


Architecture 


In our application it’s important to distinguish between the 
(virtual) drawing area for the Objects and their actual on- 
screen representation. The drawing operation is carried 
out in the background on an Object of the Class ‘System. 
Drawing.Graphics’ from the .NET-Framework. For prepar- 
ing the drawing area and managing the drawing objects 
we implement the Class ‘Grafic’. The output you see on the 
screen results from within a top-level element called ‘Pic- 
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tureBox’. This is how the dimensions of the drawing surface 
(background bitmap) can be determined independently of 
the output area actually visible (which is limited by the dis- 
play screen size you are using). The extract area displayed 
at any given time can be shifted by means of scroll bars 
(see Figure 2). 


Individual drawing objects are managed in an Array that 
goes by the name of ‘Figure’. It is defined like this: 


public Object[] Figure; 

As the type of the elements is defined simply as ‘Object’, all 
kinds of drawing objects can be stored in the Array. 
Finally there is also provision for temporary drawing 


Figure 1. 

In Visual Studio we can 
display the Characteristics 
and Methods of an Object 
in overview form. 


Figure 2. 

Our graphics program 
distinguishes between 
the virtual drawing board 
and the extract actually 
displayed. 


Figure 3. 

In the Class diagram we 
can see which drawing 
objects are derived from 
other Objects. 
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Figure 4. 


The sequential diagram 
indicates how the Objects 
in our sample application 


interact. 


Figure 5. 


The graphics program 
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in action. 
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objects, which can for example be used to visualise the 
lateral shifting of an object. This is achieved by making a 
copy of the original object before this shifting takes place 
and altering this copy during the period of user interaction. 
To inform the user what moving the original object would 
do, one of these temporary objects is displayed directly on 
the relevant output area. 


Base Objects 


The graphics framework of .NET provides us with a series of 
drawing functions (Base Objects). These Base Objects cre- 
ate very simple geometric figures (such as Line, Rectangle 
and Circle). Base Objects are assembled in a Class hierar- 
chy and Figure 3 shows a so-called Class diagram. The 
top Base Object is the Class Object. This one is concerned 
with a so-called abstract Class, meaning that no Instances 
can be created from this Class. However, the Class Object 
already contains all of those Characteristics and Methods 
that are of significance for the Classes that follow on. In the 
construction of our Class library the principles of generalisa- 
tion and specialisation are followed strictly. Characteristics 
and Methods that are valid for more several Objects are 
assigned to a superior Class. Specials — characteristics 
valid for a single drawing object only—are implemented 
in the corresponding Special Class. 


Interactivity 


As in most graphics applications here too we require inter- 
action with the user. This includes, for example, the ability to 
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draw or shift objects. The interactive drawing process itself 
is controlled by the Mouse Events ‘MouseDown’, ‘MouseUp’ 
and ‘MouseMove’. In the so-called sequence diagram (Fig- 
ure 4) our example shows how a line is drawn. To illustrate 
the drawing process a temporary object is indicated in the 
output area with each mouse movement, before the old 
object is erased. If the left mouse button is activated during 
the drawing process, the coordinates of the current loca- 
tion are stored. After this, selection of the next point of the 
figure can take place. Once all points in our figure have 
been defined in this way the temporary figure is transferred 
into the object store. 


Users also need to use the mouse for marking Objects. With 
each mouse click a test is made to check whether there is 
an object located at this position. If no object is found at 
the mouse position and a different object has already been 
selected, this marker is cancelled. CheckForObject (int x, 
int y) is responsible for this Method, using the coordinates 
of the mouse pointer as parameters. If these are found to 
be located inside an Object (Rectangle, Circle) or on an 
Object (Line), then the result is reported as ‘true’. In the 
negative case the report back is ‘false’. Objects created 
on one occasion should also be capable of being edited 
subsequently and for this we use the Method ‘EditSize’ of 
the drawing object concerned. 


Expansion 


Figure 5 shows our application in action. The ability to 
create objects in almost any form we wish on a drawing 
board and then move them around makes this a pretty good 
starting point for all kinds of graphic applications that crop 
up daily in electronics. What, for example, if we wanted to 
turn data measurements into a bar chart? No sooner said 
than done. The starting point of our Class Diagram is the 
Class ‘Special’ (see Class Diagram in Figure 2). Listing 2 
gives the code of this Class. Following the colon in the first 
line the compiler is informed that the Class Diagram inherits 
the Characteristics and Methods of the Class ‘Special’. 


Near the top of the listing an Array called ‘Data’ is defined 
and this records the test measurement data for the bar 
chart. The Method Diagram() is the so-called Constructor 
of the Class. This is always called when an Instance of the 
Class Diagram is produced. Following this are a couple of 
Method definitions with the keyword ‘override’. This means 
that when the Method is called, it does not use the code of 
the inherited Method (implemented in the Class ‘Figure’). 
Instead new code is assigned, which overwrites the inher- 
ited code. After all, it’s not particularly helpful to, say, rotate 
a bar graph by a specific angle. The Method ‘Rotate’ in this 
new Class is therefore implemented without code; when you 
call it up simply nothing happens. 


The Method ‘Draw’ produces the bar graph. The two state- 
ments Grfc.FillRectangle and Grfc.DrawString are of major 
significance, as they draw a bar for each value of data and 
write the value above it. 


You can test out the whole thing by starting up the applica- 
tion and in the ‘Extra’ menu selecting the drop-down option 
‘Plot Data ...’ (see Figure 6). The program then instructs 
you to select a text file that contains a simple listing of meas- 
urement values (for example the sample file data.txt, to be 
found in the source code package [2]}. If you then click on 
the drawing board, you can make the bar graph larger and 
move it around. This functionality ‘inherits’ the Class Dia- 
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gram of the Class ‘Special’, which in turn is derived from 
the Class ‘Figure’. The programmer must not implement the E MainForm - [Grafic] 
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feature for the Class Diagram, not even once! 


The source code of this exercise is at your disposal for 
developing your own expansion ideas, so get cracking! The 


code (created with Visual C# 2008, Express Edition) can be 
downloaded gratis at the web page for this article [1]. 


(080752) 


Internet Link 
[1] www.elektor.com/080752 


Author’s email 
veikko2000@yahoo.de Figure 6. 

The Class ‘Diagram’ is 
derived from the Class 
‘Figure’ via the Class 
‘Special’, enabling a 

bar graph to be created. 
The ‘shift’ and ‘enlarge’ 
functions are implemented 
automatically. 
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Listing 2. The Class ‘Diagram’ (extract) 


public class Diagram : Special 


{ 


int[] data = new int[15]; 
public Diagram () 


{ 
NumberOfPoints = 2; 
fp = new PointF[NumberOfPoints] ; 
} 
public override void Rotate (Double Winkel) 
{ 
} 
public override void Draw(Graphics Grfc) 
{ 
Grfc.DrawPolygon(Stift, fp); 
int maxValue = 0; 
for (int i = 0; i < data.Length; i++) 
{ 


if (data[i] > maxValue) maxValue = datal[i]; 
} 
int maxWidth = (int) (fp[2].X - fp[0].X); 
int maxHeigth = (int) (fp[2].Y - fp[0] .Y)-20; 
int width = maxWidth / 31; 
int buctom = (int)fp[2].Y; 
int left = (int)fp[0].X + width; 
Brush brush = new SolidBrush(Color2) ; 


if (maxValue != 0) 

{ 
for (int i = 0; i < 15; i++) 
{ 


int currentHeigth = maxHeigth * data[i] / maxValue; 
Rectangle rect = new Rectangle(left + 2 * 
i * width, buttom - currentHeigth, width, currentHeigth) ; 
Grfc.FillRectangle(brush, rect) ; 
Grfc.DrawString(data[i].ToString(), new Font(“Arial”, 8), new 
SolidBrush(Color.Black), new PointF(left + 2 * i * width, buttom - currentHeigth - 15)); 


} 
} 
public override void SetData(int[] Data) 
{ 
Data.CopyTo(data, 0); 
} 
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sees” E-BLOCKS 


ECIO40 and USB 


Connect a PIC to USB 
within 10 minutes 


Bert van Dam (The Netherlands) 


Analogue and digital signals can be measured easily using an E-blocks ECIO module. With the right 


drivers it becomes a simple matter to read these values on a PC via a USB link. In this article we show 


how this can be implemented within 10 minutes. 


ECIO40 
(18F4455) 


Ne 10k _| 
a 
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Figure 1. The circuit diagram reveals that very little hardware is required for this project. 


The ECIO40 is a modern 18F4455 PIC 
microcontroller mounted on a mini PCB 
and includes an integrated USB boot- 
loader. You can therefore program the 
ECIO40 without the need for an expen- 
sive programmer. All you need is a 
spare USB port on your PC and a small 
(free) program. The ECIO40 module is 
available from the Elektor Shop. 

A new feature is that you can now use 
the same USB port to communicate 
directly with the ECIO40. This offers a 
whole new range of possibilities. You 
can for example turn it into a mouse 
or joystick, or use it to make measure- 
ments and display and process them 
on your PC. 


62 


In this article you can find out how to 
measure an analogue and digital signal 
with the ECIO40 and then show them 
on your PC via a USB connection. 


Hardware setup 


The analogue signal is created using 
a potentiometer that has been wired 
up as a potential divider to provide 
a voltage between 0 to 5 volts to pin 
AO of the ECIO40 (see Figure 1). For 
the switch we've used a reed switch. 
This is a type of switch that reacts to 
the presence of a magnetic field. The 
switch, which consists of two contacts 
inside a glass tube, is normally open. 


Quick Specifications 
© ECIO modules available from Elektor 
@ Works under Windows XP and Vista 


@ No power supply required; it uses the 
USB supply 


@ Connected within 10 minutes 


@ USB driver generated by Flowcode 


@ Simple communications via 
HyperTerminal 





When you hold a magnet near it the 
contacts are attracted towards each 
other and the switch closes. 


This type of switch is often used in 
burglar alarms. You could for example 
mount the switch on a doorframe and 
the magnet in the door itself. When 
the door is opened the switch opens 
as well, which can then set off an 
alarm. You can of course use an ordi- 
nary switch in this setup as well. 
Apart from the ECIO40, a few compo- 
nents and Flowcode V3, you also need 
the USB pack for this project. This can 
be downloaded from the website of 
Matrix Multimedia [1]. Note that you 
need the licence number from your 
Flowcode CD for this. 


Get cracking 


First of all the circuit is constructed on 
a piece of experimenter’s board. The 
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Figure 2. After installation of the USB pack the extra hardware 
components appear in the component tray. 


supply for the circuit comes via the 
USB port of the PC, so you won't need 
a separate power supply. 

Next you have to install the USB pack 
in your version of Flowcode. We rec- 
ommend that you first upgrade to the 
most recent version of Flowcode V3 
if you haven't done so already. After 
you have unzipped the USB pack you 
should copy the Flowcode V3 folder to 
the folder with the same name in the 
Flowcode installation (this is usually 
in C:\Program Files\Matrix Multime- 
dia). Next you should run the program 
‘Install USBPack.bat’, which is in the 
Flowcode V3 components folder, in 
order to register the new components. 
On most PCs you should be logged in 
as Administrator, or have administra- 
tive rights, in order to do this. When 
you next start up Flowcode you'll find 
that three extra hardware components 
have appeared in the components tray 
(Figure 2). 


In this article we make use of the 
‘serial’ component. This component is 
specially made to use a USB port with 
traditional communications packages 
such as HyperTerm. Click on it in order 
to add the component to your project, 
which makes the following USB mac- 
ros available for use: 
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® Initialise serial 
® SendByte 

® SendString 

® ReadByte 

® ReadString 


We start the program with an Initial- 
ise serial macro. The result of this 
macro can be stored in a variable (for 
example, retval). In this demo project 
we don’t make further use of it, but 
you can use the variable to see if the 
USB connection was actually made 
successfully (retval=O), or if it hadn't 
(retval=255). A loop starts next, where 
the analogue and digital signals are 
measured and sent to the PC. 


Hyperterm 


On the PC side something should be 
done with these measurements. Since 
the USB component is meant to be 
used with a traditional communica- 
tions package, we chose to use the 
HyperTerm program. This communica- 
tions program is included for free with 
Windows XP and earlier versions of 
Windows. Vista users can use Hyper- 
Terminal Private Edition, a free soft- 
ware package from Hillgraeve. Unfor- 
tunately, the free version is no longer 
available from this company, but via 
Google (search for ‘htpe download’) 
you can still find many places where 
you can legally download a copy of the 


Variable 


Reedswitch 


free version. This version happens to 
have more functions than the one sup- 
plied as standard with Windows XP 
and earlier, which makes it a worth- 
while download for XP users as well. 
The reason for using this particular 
package is that it permits the micro- 
controller to control the cursor on the 
PC screen. There are three commands 
that have been used in this project: 


1. Esc H, put the cursor in the home 
position, at the top-left of the 
screen. 

2. Esc Yr,c, position the cursor in row 
rand column c. 

3. Esc J, clear the screen from the 
cursor onwards. 


With these commands it is easy for 
the microcontroller to create a screen 
image and then send it to the PC. A 
small complication is that the values 
r (the row) and c (the column) have 
to be expressed in ASCII for histori- 
cal reasons, and should therefore be 
increased by 32. For example, if you 
want to select row 11, you have to add 
32 to it (resulting in 43) and then send 
the character that has this ASCII value, 
in this case a ‘+’. In the download for 
this article [2] you'll find a table that 
you can print out, which makes it a lot 
easier to choose the right character to 
position the cursor on the screen. The 
design for this project, which uses this 
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Figure 3. Screen layout for this project. 
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Figure 4. Flowcode for the initialisation of the USB connection and displaying the first line of text. 
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Figure 5. An ADC measurement followed by the transmission of data via USB. 


table, is shown in Figure 3. 

To place the cursor on the top-left of 
the screen we need to send an Esc H 
command. The ASCII value for Esc is 
27, so we first send ‘27’ via the USB 
link, followed by an ‘H’. The first line 
of text can be added to the end of that 
command. We make things a bit eas- 
ier by adding a few spaces to posi- 
tion the text in the correct column (see 
Figure 4). 


Flowcode 


Next an analogue measurement has 
to be made via pin AO. First an ADC 
component is added to the workspace; 
next it is assigned to the analogue/dig- 
ital converter on pin AO (i.e. ADCO) and 
instructed to carry out an ADC meas- 
urement, with a byte as the result. The 
variable that holds the measurement 
is called ‘potmeter’. You can’t send 
the value of ‘potmeter’ directly to the 
PC because HyperTerm then thinks 


you're sending it a single character. 
Should the value of potmeter be 65 for 
example, then HyperTerm will display 
the letter A (which has an ASCII value 
of 65) instead of the number 65. This 
problem is solved by converting ‘pot- 
meter’ into a string. 


The measured value is preceded by the 
text ‘Variable resistor’ and from Fig- 
ure 3 you can see that the text starts 
at screen position $#: row 4, column 3 
(counting starts at zero). The command 
Esc Y is used to select screen positions 
and this also permits the text to be 
sent as part of the command. The sec- 
ond program section ends up as shown 
in Figure 5. 


After the value has been sent, a few 
trailing spaces are added. Numbers in 
Flowcode are left justified. Since the 
screen isn't cleared, but is simply over- 
written, a measurement of ‘8’ that fol- 
lowed a measurement of ‘100’ would 


reedswkch=Switches(0)::Readstate(0) 


US8SerialO}::SendByte(27) 
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Figure 6. Determine the state of the reed switch and send it via the USB link. 
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be displayed as ‘800’, because the two 
zeroes would not be overwritten and 
would therefore still be visible. Add- 
ing a few spaces at the end avoids this 
problem. 

The next step is to determine the state 
of the reed switch. Although it is mag- 
netically activated, technically it is no 
different from an ordinary switch. You 
can therefore use a standard Flow- 
code switch component. After add- 
ing this to the workspace the state of 
the switch can be put into a variable 
using the macro ‘readstate’. We've 
used ‘reedswitch’ as the name for this 
variable. Instead of a 0 or 1 it looks a 
lot better if the display shows ‘on’ or 
‘off’. We use an if/then instruction to 
implement this. From Figure 3 you can 
see that the text starts at position &#, 
which makes the final part of the pro- 
gram look like Figure 6. The Flowcode 
design files can be downloaded free of 
charge from the Elektor website [2]. 
The microcontroller program is now 
complete and can be programmed into 
the ECIO40. Once this has happened 
you'll get a message from your PC 
stating that new hardware has been 
found. Ignore this message, but leave 
the window open! We will need this at 
a later stage. 


USB driver 


On the PC side we now need a USB 
driver that receives the data from the 
microcontroller via the USB port and 
then converts it into a virtual COM 
port, which is a COM port that doesn’t 
exist in hardware, but still appears 
to exist to a program running on the 
PC. The program can communicate 
with this virtual COM port in exactly 
the same way as if it was a hardware 
based COM port. 


The USB driver is created using Flow- 
code. On most PCs you should be 
logged in as Administrator, or have 
administrative rights, in order to carry 
out the following steps. 

Open the Flowcode USB component. 
We'll ignore the VID and PID for the 
time being. Next click on the button 
‘Generate driver file’ (Figure 7). You 
can accept the suggested driver name 
or think of one yourself. The extension 
(.INF) is automatically added. Store 
the driver in the same folder where the 
rest of your project is stored. This isn’t 
compulsory, but if you don’t do this you 
could end up with a large number of 
drivers and forget which project they 
belong to. 
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Figure 7. Properties of the USB component in Flowcode. 


If all is well, the window with ‘found 
new hardware’ should still be open. 
We can now continue with this. Don’t 
give permission to connect to the Inter- 
net (your new driver will obviously not 
be found there) and on the next screen 
state that you want to install the driver 
from a specific location. Type in the 
folder where the Flowcode-gener- 
ated driver is stored. It should then be 
installed automatically. 


Wait until the driver has been com- 
pletely installed. The computer should 
have automatically allocated a number 
for the virtual COM port. That number 
can be different for different PCs. Go to 
the Device Manager (via Control Panel 
-> System -> Hardware) and look which 
COM port uses this driver. For our PC 
it is COM6 (see Figure 8). 


Start HyperTerm and enter the follow- 
ing communications settings: 


® Connect using ‘6’ in our case. 
(It could be different for you.) 


® Bits per second 38400 
® Data bits 8 

® Parity none 
® Stop bits 1 

® Handshaking none 


You could use other speeds as well, 
without needing to change the Flow- 
code program. If you prefer to use 
9600 baud, all you need to do is just 
fill it in. The driver and the USB port on 
the microcontroller will automatically 
adapt to this speed. 

After HyperTerm is started you'll see 
the screen shown in Figure 9. When 
you rotate the potentiometer, or hold a 
magnet near the switch, you'll see the 
changes on the screen. 
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Error messages 


If the screen isn’t static, but starts 
scrolling, then from HyperTerm you 
should go to File -> Properties -> Set- 
tings and set the emulation to VT52. If 
you should see the message ‘Invalid 
COM port’ or similar appear in Hyper- 
Term, you probably haven't connected 
the ECIO. The virtual COM port only 
exists when the ECIO is connected 
and the bootloader has completed. The 
correct order of events is therefore: first 
connect the ECIO, wait until the LED 
stops flashing and only then start up 
HyperTerm. 


If the PC shows the message ‘New 
hardware or driver not found’ it may 
be caused by the following: when the 
ECIO is plugged into the USB port of 
the PC, the PC uses the VID and PID 
numbers (you will have come across 
these in the USB serial component) to 
search for the matching driver. If you 
have changed either of these num- 
bers then the PC won't recognise the 
ECIO and you will have to create a 
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Figure 8. The virtual COM port in the Device Manager. 


new driver (or put the numbers back 
to their original value). 
(080817-1) 


Internet links 


[1] www.matrixmultimedia.com/FlowcodeUS- 
BPack.php 


You should have the serial number from your 
Flowcode CD to hand. This pack contains 
examples of USB-slave and USB-HID connec- 
tions including the Visual Basic 6 source code 
and an interface with LabVIEW. 


[2] www.elektor.com/0808 1 7 
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Frank Link (Germany) 


Not having enough ports on a microcontroller to drive all the functions of a circuit is a commonly- 


encountered problem. The clever port expansion boards described here offer a solution, and need just 


four signals from the microcontroller. The first board provides sixteen digital output bits; the second 


board, equally simple to drive, can be used to interface to a HD44780-compatible LCD module. A C 


library is available to facilitate using the boards with AVR microcontrollers. 


Some time ago the author developed 
a board to drive a motorised poten- 
tiometer using an ATmega8. Several 
outputs of the microcontroller were 
wired in parallel to increase the cur- 
rent available and thereby avoid the 
need for an extra motor driver IC. Just 
five port pins were left over on the 
ATmega8, which made implement- 
ing the remaining functionality of the 
board rather tricky. 

Undaunted the author carried out a 
thorough search of the Internet for 
simple ways to expand the number 
of available ports. Finally, however, 
he decided to design his own hard- 
ware- and software-based solution to 
the problem. The design was based on 
the well-known 74HC595 shift register, 
which can be driven using an SPI bus. 
Unfortunately, however, the SPI pins 
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of the ATmega8 were already commit- 
ted, and so the SPI protocol had to be 
implemented in software. The result 
of the work is described here: a solu- 
tion which is suitable for all types of 
microcontroller, with four spare port 
pins required to drive the port expan- 
sion circuit. 

We have made a C library available 
for free download: this supports AVR 
microcontrollers, but it is relatively 
straightforward to modify the source 
code to adapt it to other device fam- 
ilies. The library allows the user to 
control not just one, but any number of 
connected 74HC595s! 


In the interests of ease of use the 
author produced two printed circuit 


boards, whose layout was subse- 
quently refined at the Elektor labs. 
Both boards are available from Elektor 
[1]. 

The first printed circuit board is based 
around two '74HC595s. This provides a 
port expansion to sixteen output bits; 
the boards can be cascaded if even 
more outputs are required. 

Figure 1 shows how the 74HC595 is 
driven. The SDI (serial data in) signal is 
used to send data to the device. With 
each pulse on SFTCLK (shift clock) the 
data bits are synchronously shifted one 
place along the registers. Then a pulse 
on LATCH CLOCK transfers the loaded 
data from a holding register in the 
74HC595 into the output register, and 
the levels on the output pins change to 
reflect the transmitted data. 

The OE signal is dedicated to a special 
function of the 74HC595. In order to 
avoid the situation where the outputs 
of the device go to an undefined state 
when power is applied, this signal can 
be held high using a pull-up resistor 
(via JP1 in Figure 1). This ensures that 
all the 74HC595’s outputs go instead to 
a high impedance state when power is 
applied: a pull-up or a pull-down resis- 
tor can be connected to each output to 
make sure that it carries the desired 
logic level in this state. 

If the jumper is not fitted OE can be 
driven from the microcontroller: this 
requires a fifth spare output pin, of 
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Figure 1. How to drive a 74HC595. 


course. Code to use OE when initial- 
ising the 74HC595 is implemented in 
the author’s software library, but can 
be excised if it is not required. 

Figure 2 and Figure 3 show the circuit 
diagram and printed circuit board lay- 
out for the port expansion unit. Two 
74HC595s are connected in cascade 
to double the number of available out- 
puts. Cascade connection involves wir- 
ing the clock signals in parallel, and 
the input of the second 74HC595 to 
the output of the first. When a pulse is 
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Figure 2. Circuit diagram of the port expansion unit. 


applied to SFTCLK, data bits are first 
shifted through the first device and 
then through the second. 

The microcontroller is connected to K5. 
As all five pins are connected to both 
rows of the two-row header it is pos- 
sible to connect the signals through to 
a second port expansion board and so 
use further 74HC595s. Note, however, 
that the SDI pin of the second board 
must be connected to the SDO pin of 
the first. 

Power is supplied to the board via 


K1, and K2 allows this power to be 
delivered to cascaded boards. K3 and 
K4 carry the output signals from the 
74HC595s, while JP1 determines how 
the OE signal is driven. 


As is conventional, the software 
library comes in two parts. The 
first is a header file com74hc595. 
h which includes function declara- 
tions and definitions of the port pins 
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ee 


Listing 1. Function com74hc595_out() 


void Com74he595 out () 


{ 


unsigned char count = COM74HC595 SIZE; 
unsigned char* serp = com74hc595 + COM74HC595 SIZE; 


do 


{ 


unsigned char bits; 


/* fetch byte from array com74hc595[] */ 


unsigned char data = *--serp; 
/* shift out 8 bits per byte */ 


for (bits = 8; bits > 0; bits--) 

{ 

PORT_COM74HC595 &= ~(1<<PORT_SER) ; 
(data & 0x80) 

{ 

PORT_COM74HC595 |= (1<<PORT_SER) ; 

ba 


data <<= 1; 


/* a pulse on the clock signal shifts the data synchronously */ 
/* by one place through all the shift registers */ 


PORT _COM74HC595 &= ~(1<<PORT_SCK) ; 
PORT _COM74HC595 |= (1<<PORT_SCK) ; 
while (--count > 0); 


/* a pulse on RCK transfers the data from the shift re- 


gisters to the output latches */ 


PORT_COM74HC595 &= ~(1<<PORT_RCK) ; 
PORT_COM74HC595 |= (1<<PORT_RCK) ; 


ı if 


(«cs kh imdb ty, a a a amt a A A iy mip tm a E a my» my mi mt a a 


and number of '744HC595 devices con- 
nected (COM74HC595 SIZE). The sec- 
ond is a.c file containing the C source 
code that actually drives the ports. The 
header file will generally need to be 
modified by the user to specify which 
port pins on the AVR microcontroller 


ee 


Listing 2. Simple running light 


#include <avr/io.h> 
#define F CPU 3686400 
#include <util/delay.h> 


#include “com74hc595.h"” 

int main (void) 

{ 

com74he595. init(); 

while (1) 
{ 
for ( int i = 0; 
{ 


com74hc595_out (); 
_delay_ms( 2000 ); 
delay ms( 2000 ); 
com74hc595 unsetBit ( 
com74hc595_out (); 
_delay_ms( 2000 ); 
_delay_ms( 2000 ) 


1 
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i < com74hc595_BYTES; i++ ) 


com74hc595 _ setBit( i ); 


wee ee ee ee Be ee ee ee ee ee eB ee ee ee Be ee ee ee ee ee eH AKG 


Shim iy im a a a a, e Ga E a a a a a a a a a a a G a a a E a a E a aa a a a A 


are connected to which signal on the 
74HC595 board. There is one restric- 
tion: the pins used must all belong to 
the same port, defined in the header 
file as PORT COM74HC595. 

The application program must first call 
the function com74hc595 init(). This 
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Figure 3. Port expansion printed circuit board. 
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COMPONENT LIST 


LCD board 


Resistors 

R1,R2 = 1kQ 

R3 = 4kQ7 

P1 = 10kQ preset 


Capacitors 
C1,C2 = 100nF 


Semiconductors 
Tl = BC557 
IC1 = 74HC595 


Miscellaneous 

K1 = 2-way pinheader 

K2 = 10-way pinheader (2x5) 

JP1 = 3-way pinheader with jumper 
PCB no. 080682-1 [1] 
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initialises all the variables and con- 
stants used within the library. When 
this call completes all the 74HC595 
outputs will have been set low. 

The functions com74hc595_ setBit() 
and com74hc595 _ unsetBit() address 
the individual output pins. Setting 
bits according to a specified bit pat- 
tern can be achieved using the func- 
tions com74hc595 setPort() and 
com74hc595_ unsetPort(). Functions 
com74hc595 setall() and com74hc595 _ 
unsetall() can be used to set all port 
pins high or low respectively with a 
single call. 

The actual work of driving the 
74HC595s is carried out in the func- 
tion com74hc595 out(): see Listing 1. 
It synchronously clocks the individual 
bits, stored in a character array called 
com74hc595[], through the chain of 
74HC595 devices. The operation pro- 
ceeds in reverse order, starting with 
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Port expansion board 


Resistors 
RI = 1kQ 


Capacitors 
C1,C2 = 100nF 


! Semiconductors ! 
! IC1,IC2 = 74HC595 ! 


Miscellaneous 

K1,K2 = 2-way pinheader 

K3,K4 = 8-way pinheader 

K5 = 10-way pinheader (2x5) 

JP1 = 3-way pinheader with jumper 
PCB no. 080682-2 [1] 
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the last bit. One bit is transferred into 
the chain by taking the clock signal 
low and then back high. When all bits 
have been sent, RCK is taken high and 
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Figure 5. Circuit diagram of the LCD interface circuit. 


then back low. 
A simple running light application 
example is shown in Listing 2. 


LCD interface 


It is very common in microcontroller- 
based applications to want to display 
the values of internal variables. This 
gives rise to the idea of controlling 
a HD44780-compatible LCD module 
over just four wires with the help of 
a 74HC595. In addition, we can also 
allow the microcontroller to switch a 
backlight on and off. 

The resulting circuit is shown in Fig- 
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ure 4 and Figure 5. The LCD is con- 
nected to the outputs of the 74HC595: 
as the module is to be used in four-bit 
mode, pins DO to D3 of the LCD are 
connected to ground. The functions of 
K2, K1 and JP1 are as described above 
for the port expansion board. 

The 10 kQ trimmer should be soldered 
to the track side of the board to sim- 
plify adjusting the LCD contrast after 
assembly. All the other components are 
hidden underneath the LCD module. 
The author has also written functions 
to control the LCD and made them 
into a library. Again this comprises a 
header file (com74hc595 LCD.h) and 
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the main C code file. The central func- 
tions are com74hc595 lIcd_nibble() 
and com74hc595 lcd _enable(); all the 
other functions are built upon these 
routines. 

In com74hc595_Icd_nibble() (Listing 3) 
the four data bits are first set to zero. 
Each bit is then checked to see if it 
needs to be set: the backlight flag must 
be included in the same bit array, and 
so its state must also be tested and the 
appropriate bit set if necessary. Finally 
the information is sent to the 74HC595 
using com74hc595 out(). 





The function com74hc595_Icd_enable() 
(Listing 4) tells the HD44780-compat- 
ible LCD controller that new data bits 
are available. This is done by setting 
the LCD’s enable signal (EN) high for 
20 us and then low again. 

Before the library can be used a cou- 
ple of settings need to be made in the 
header file [1]. The first is the clock fre- 
quency at which the microcontroller is 
operating: this is needed to ensure that 
the timing for the LCD can be calcu- 
lated exactly. If the LCD board is used 
as one member of a chain on 74HC595s, 
the macro LCD PORT needs to be 
adjusted to reflect its position within 
the chain. It is also of course neces- 
sary to specify which port pins are to 
be used for the SPI port. 

Listing 5 shows our version of the 
familiar ‘Hello World’ example program, 
demonstrating correct initialisation of 
the two libraries and subsequent use 
of the LCD driver functions. The full 
range of commands available in the 
library is described in the supplemen- 
tary documentation available for down- 
load (along with source code) from 
the project pages accompanying this 
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article [1]. The author is continuing to ° 
work on further expansion plans, and Internet Link 
interested readers are invited to con- [1] www.elektor.com/080682 
tact him by e-mail at FrankLink61@ 
aol.com. 

(080682-1) 


poo ee ee He He eee ee eK eH ee ee Re ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee eee eK HK K-1 


Listing 3. Function ..lcd_nibble() 


void com74hc595 lcd nibble ( unsigned char d ) 


! com74hc595 unsetBit( LCD B4 J} 
com74hc595 unsetBit( LCD B5 ); 
! com74hc595_unsetBit( LCD B6 ); ! 
i com74nc595 unsetBit( LCD By )} l 
if ( d & 1<<4 ) com74hc595 setBit( LCD B4 ); 
l if ( d & 1<<5 ) com74hc595_setBit( LCD B5 ); l 
i if ( d & 1<<6 ) com74hc595 setBit( LCD B6 ); 
if 4 d & Iee7 ) com74hc595 secBit( LCD B7 ); ; 
if ( BackLightState == ON ) com74hc595 unsetBit( LCD LIGHT ); 
if ( BackLightState == OFF ) com74hc595_ setBit( LCD LIGHT ); : 
com74hc595_out (); 
com74hc595_ lcd enable(); 


ee ee ee ee ee ee ee ee ee ee ee 
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Listing 4. Function ..lcd_enable 


void com74hc595 lcd enable (void) 


{ 
com74hc595 out()j; 
_delay_us(20) ; 
com/74he595 unsetBit LCD EN ); 
com74hc595_out (); 

} 


! com74hce595_setBit( LCD EN ); | 


Eke e e n a l a M a A a l l U M U M a l ee ee a ee ee ee a a a G ee G ee 


Pes =e ee ee ee ee ee XXX ee eB eB ee eB eB eB eB eB eB eB eB ee HG 


Listing 5. ‘Hello World!’ 


#include <avr/io.h> 
#include “com74hc595.h” 
#include “com74hc595 LCD.h” 


! int main(void) ! 
Ii 
i com74hc595 init (); i 
com74hc595 lcd init(); 
ecom74nes9s led light onj; 
com74hc595_1cd data(`T'); 
com74hc595 lcd data (`e i 
com74hc595 lcd data (` 


S 
com74hc595_1cd data(`t' 
( 
( 


1 
1 


| 
); 
DE 
F 

0,2); 

“Hello World!”); 


com74hc595_set_cursor 
com74he595 Lled string 
while (1) 


return 0; 
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Antoine Authier (Elektor Labs] 


| had to go twice to China, to launch and then monitor production of the Elektor reflow oven. 
When I visited the city of Shenzhen, a real world centre for the production of electronic 
appliances, one place | visited is going to haunt my memory as an electronics technician for 


a long time: an electronic component market. 


How can | describe such a place? Market, big store, hyper- 
market... At first sight, the way the merchandise is displayed 
in bulk brings to mind the profusion of a fruit and vegetable 
market, with its varying degrees of order — or disorder. In 
the centre of the building, you find all grouped together the 
passive components — resistors, inductors, and capacitors 
— together with crystal oscillators and certain cheap dis- 
crete semiconductors like triacs, transistor, LEDs, and so on, 
along with mechanical com- 
ponents like potentiometers, 
push-buttons, switches, etc., 
and spacers, washers and 
screws. Here and there 
near the entrances, there are a few tools on offer, like for 
example multimeters and soldering irons. 


.. | get lost. 


Higher added-value semiconductors, hard to find singly but 
readily available on reels or in trays, are mainly sold from 
small glazed stands round the edge of the building. 

The layout, abundance, and diversity of the components 
brings to mind a Wallmart-like hypermarket. The prices are 
incredibly low. Rumour has it that certain of these market 
traders are selling empty cases! | don’t know if that’s true, 
but in any event, the oscillators | found there for one of our 
forthcoming projects work perfectly. 

Once over this initial wonderment, a little pause is called 
for: | spot the escalators, allowing me to gain a little height 
and discover the immensity of the place I'd just been tour- 
ing. The visit goes on and on, floor after floor, and in the 
absence of comprehensible directions for finding this or that 
product, | get lost. It's a jungle! 


Even though it’s all a bit like a department store, it seems 
to me jolly badly organized. | pop out for a moment for 
a breath of air — no less polluted outside than it is stale 
inside. Once outside, you only have to cross the road to 
enter another building housing another component market 
just like the first. The centre of Shenzhen comprises a whole 
block of immense skyscrapers, totally dedicated to the sale 
of electronic equipment. 

Everything imaginable is sold there, from ancient transis- 
tors in TO3 packages to the latest ARM core, via drums of 
cable, OEM modules, measuring instruments... For Western 
visitors (if they don’t speak Chinese), the difficulty is find- 


Hyper Flea Market! 


Seemed like it was raining com 


It’s a jungle! 


ing things... 

The market sellers are usually crammed into a tiny square 
shop, behind a transparent counter displaying their main 
lines and leading products, surrounded on three sides by 
overloaded shelves. Thankfully, sales don’t take place at 
the top of people's voices — the atmosphere is rather calm. 
Despite an impressive number of air-conditioning units, the 
air is hot and heavy. 

Business is brisk, but in the 
endless series of shops, 
it’s not uncommon to see 
stallholders who've fallen 
asleep, or young mothers 
occupied with their babies. When they're not patiently wait- 
ing for customers, the traders can often be seen playing 
on their portable computers, which take the place of cash 
Ke ey 

It all makes a fascinating sight. | saw, for example, one 
young woman who was sorting oscillators in tiny SMD 
packages at an improbable speed, without ever making 
a mistake. 


So just who are the customers that come here? Hard to tell. 
There are lots of small electronics production companies 
in this area; | imagine that their proprietors come to buy 
components for their daily production. You also find a few 
tourists, who are easy to spot! 

In these markets, just like everywhere in Asia, you can eat 
and drink at any time of the day. In Summer, the 
heat is intense, so it’s a 
good idea to come 
armed with a small 
fan and some cold 
drinks. A notepad 
and pen will prove 
very useful — along 
with a good sense of 
direction! 
Communicating in Eng- 
lish with the Chinese in 
China, especially in a 
place like this, seemed 
to me very hard if not 
impossible. An inter- 










































ponents... 


preter is really a must for anyone who doesn’t 
(yet) have a command of Mandarin. 


In Hong Kong, there aren't any of these component mar- 
kets. Not being terribly profitable any more, this business 
has moved from the much more highly developed mega- 
polis to nearby mainland China. On the other hand, there 
are whole streets, in particular Apliu Street in the 
Sham Shui Po district of Kowloon, 
of shops for electron- 
ics tools, test instru- 
ments, and finished 
products: valve ampli- 
fiers, watches, mobile 
phones, computers, 
and spare parts for 
them. Prices here are 
comparable with those in 
Europe — but of course, 
less tax. 


Western visitors steeped in 
electronics should certainly 
not miss out on the pro- 
found impressions left by a 
few hours of total immersion 
in one of these Chinese elec- 
tronic components markets 
like the ones in Shenzhen. It’s 
an unforgettable cultural and 
technical experience. 

(081192-1) 
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DESIGN TIPS 


PR4101 Dimmable Power LED Driver 


Burkhard Kainka 
(Germany) 


Semiconductor firm PREMA [1], 
based in Mainz in Germany, will 
be well known to many Elektor 
readers for their PR4401 device 
[2] which formed the basis of the 
LED driver board that we gave 
away with the September 2007 
issue of the magazine. That de- 
vice is capable of powering 
a white LED from a single cell. 
More recently the company has 
produced the PR4101, a step- 
down driver designed for power 
LEDs. It requires an input voltage 
of between 7 V and 40 V and at 
its output can drive one or more 
LEDs at constant current, irrespec- 
tive of fluctuations in this voltage. 
The drive current is relatively 
smooth, which is beneficial for 
the life of the LED. The external 
components required are a pow- 
er MOSFET, a coil, a Schottky 
diode and a couple of resistors 
and capacitors. Output currents 
in excess of 1 A are possible. 

The PR4101 is suitable for ap- 
plications running from 12 V or 
24 V automotive batteries, as 
well as for situations where it is 
desired to replace a 12 V halo- 
gen bulb powered from a mains 
transformer. In this case, as with 
halogen bulbs, the IC allows dim- 
ming using phase angle control. 
Further special features of the de- 
vice include an overtemperature 


C2 


© 12Vn,..24V n O 


4x 


DELAY 
PR4101 


GND SUB 


detection circuit that is also ca- 
pable of protecting the LEDs us- 
ing an external temperature sen- 
sor, reducing the drive current at 
higher temperatures. An external 
control input allows the device to 
be powered down, for example 
by a remote control, with a stand- 
by current of less than 35 pA. 

The LED current can be set using 
either an external sense resistor 
or a pulse-width modulated sig- 
nal at the device’s PWM input. 
Conversion efficiency in a typi- 
cal 12 V application with three 
3 W LEDs wired in series is over 
90 %; in the least favourable 
case (an input voltage of 40 V, 
driving a single 3 W LED) effi- 
ciency is still greater than 60 %. 
Figure 1 shows the basic 
PR4101 circuit. The LED cur- 


NDRV 
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rent is determined by the val- 
ue of the current sense resistor 
Reenser While we have fixed the 
value of resistor Rycense at 1 kQ. 
Rense is selected using the equa- 
tion Rense = 0.2 V / liep. Typical 
example values are 0.27 Q for 
3 W LEDs {lfp = 750 mA) and 
0.56 Q for 1 W LEDs (lien ap- 
proximately 350 mA). 


Figure 2 shows a circuit de- 
signed for direct connection 
to a halogen bulb transformer, 
which can either be an ordi- 
nary iron-core transformer or an 
‘electronic transformer’ (see the 
article ‘Electronic Transformers 
Revealed and Explained’ in the 
December 2008 issue). Normal- 
ly these deliver an AC voltage at 
12 V, although the circuit shown 


will operate with input voltages 
of up to 24 V. Thanks to the use 
of Schottky diodes in the bridge 
rectifier and a 470 pF electrolytic 
for smoothing, a 12 VAC input 
is enough to drive up to three 
3 W LEDs connected in series. 
The parallel combination of R1 
and R2 forms an effective current 
sense resistor of 0.47 Q / 2, or 
approximately 0.24 Q. This 
sets the LED current at around 


850 mA. 


The circuit in Figure 3 sports 
an additional rectifier in the form 
of Dó and D7. These allow the 
brightness of the connected LEDs 
to be controlled by a dimmer 
switch employing either a con- 
ventional thyristor or TRIAC ar- 
rangement or an electronic dim- 
mer or electronic transformer. 
The PR4101 can be used with 
dimmers that use either leading- 
edge or trailing-edge phase con- 
trol. The undervoltage detection 
input VDI is fed from the AC in- 
put, rectified by Dó and D7 but 
not smoothed. The device can 
thus observe the mark-space ra- 
tio of the dimmer control wave- 
form and switch the converter on 
and off in synchrony. The result 
is that the LED’s brightness can 
be controlled just as if it were an 
incandescent lamp. 

In the PR4101 datasheet [3] PRE- 
MA describe a demonstration 
board for the device that allows 
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all its features to be exercised. 
These include an integrated tem- 
perature sensor, temperature 
compensation of the LED current, 
and a softstart function. The cir- 
cuit of the demonstration board 
is broadly the same as Figure 3, 
and is suitable for demonstrating 
brightness control using a halo- 
gen bulb transformer with phase 
control dimming on the mains 
side. 

(080933-1) 


[1] www.prema.com 
[2] www.elektor.com/070100 


[3] www.prema.com/pdf/ 
pr4101.pdf 
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Simple guitar transmitter 


Gert Baars (The Netherlands) 


To be able to play an electric 
guitar you need, in addition to 
the guitar itself, a guitar ampli- 
tier. The guitar then needs to be 
connected with a cable to the 
amplifier, which could be con- 
sidered an inconvenience. Most 
guitar amplifiers operate off the 
AC power line. 


An electric guitar fitted with a 
small transmitter offers several 
advantages. The guitar can be 
made audible via an FM tuner 
/ amplifier, for example. Both 
the connecting cable and ampli- 
fier are then unnecessary. With 
a portable FM broadcast radio 
or, if desired, a Gettoblaster you 
can play in the street or in sub- 
way stations (like Billy Bragg) 
and everything is then battery 
powered and independent of a 
tixed power point. You may need 
a permit though. 

Designing a transmitter to do this 
is not necessary at all. There are 
currently various so-called Walk- 
man/MP3 player transmitters 
available at very low cost. The 
range of these devices is often 
not more than 10 meters, but 
that’s plenty for our application. 
For this purpose we bought such 
a transmitter, the brand name of 
which is König and the model 
type is FMtrans20. After fitting 
the batteries and turning the 
transmitter on, a carrier signal 
can be detected on the radio. 
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HF 


Four channels are available, so it 
should always be possible to find 
an unused part of the FM band. 
A short cable with a 3.5 mm 
stereo audio jack protrudes from 
the enclosure. This is the audio 
input. Having taken some meas- 
urements, it appeared that the re- 
quired signal level for sufficient 
modulation is about 500 mV,,.. 
If a guitar is connected directly, 
the volume level of the radio will 
have to be turned up very high 
to get sufficient sound, so hig 

that the noise from the modula- 
tor becomes quite annoying. A 
preamplifier for the guitar signal 


Or 
x PR*101 


ca. 30 cm 
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is therefore essential. 

To build this preamplifier into the 
transmitter we will first have to 
open the enclosure. In our unit 
this is done with four screws in 
the battery compartment. Af- 
ter opening the enclosure and 
a little investigation it appears 
that the two audio channels are 
combined. This is therefore a 
single channel (mono) transmit- 
ter. Because the audio pream- 
plifier can be turned on and off 
at the same time as the transmit 
ter, we can use the ‘on-board’ 
power supply of the transmitter 
for our power supply as well. In 





our case that was 
about 2.2 V. This 
voltage is avail- 
able at the posi- 
tive terminal of an 
electrolytic capaci- 
tor. 2.2 Volts is not 
enough to power 
an opamp. But 
with a single tran- 
sistor the gain is al- 
ready big enough 
and the guitar sig- 
nal is sufficiently 
modulated. 

The final imple- 
mentation of the 
modification in- 
volves soldering 
the preamplifier 
circuit along an 
edge of the PCB 
so that everything 
still fits inside the 
enclosure. The 
stereo cable is replaced with a 
30 cm long microphone cable, 
fitted with a guitar plug (mono 
jack). The screen braid of the ca- 
ble acts as an antenna as well as 
a ground connection for the gui- 
tar signal. The coil couples the 
low-frequency signal to ground, 
while it isolates the high-frequen- 
cy antenna signal. 

While playing the cable with the 
transmitter just dangles below the 
guitar, without being a nuisance. 
If you prefer, you could also se- 
cure the transmitter to the guitar 
with a bit of double-sided tape. 
(080533-1 
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Puzzle with an 
electronics touch 





Hopefully you’re ready to get cracking again with a Hexadoku puzzle freshly brewed for you. Get out 
your pencil, scrapbook or note paper (not a notebook), take a deep breath and participate! All correct 
solutions we receive enter a prize draw for an E-blocks Starter Kit Professional and three Elektor Shop 


vouchers. Have fun! 
The instructions for this puzzle are straightforward. 


In the diagram composed of 16 x 16 boxes, enter numbers 
such that all hexadecimal numbers O through F (that’s 0-9 and 
A-F) occur once only in each row, once in each column and in 
each of the 4x4 boxes (marked by the thicker black lines). A 


SOLVE HEXADOKU AND WIN! 


Correct solutions received from the entire Elektor readership 
automatically enter a prize draw for an 


E-blocks 
Starter Kit 
Professional 


worth £300 


and three 
Elektor SHOP 
Vouchers worth 
£40.00 each. 


We believe these prizes 
should encourage 


all our readers to participate! 


The competition is not open to employees of Elektor International Media, 
its business partners and/or associated publishing houses. 
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number of clues are given in the puzzle and these determine the 
start situation. 

All correct entries received for each month's puzzle go into a 
draw for a main prize and three lesser prizes. All you need to 
do is send us the numbers in the grey boxes. The puzzle is also 
available as a free download from the Elektor website 


PARTICIPATE! 

Please send your solution (the numbers in the grey boxes) by email to: 
hexadoku@elektor.com - Subject: hexadoku 03-2009 (please copy exactly). 
Note: new email address as of this month! 

Include with your solution: full name and street address. 

Alternatively, by fax or post to: Elektor Hexadoku 
Regus Brentford - 1000 Great West Road - 
United Kingdom - Fax (+44) 208 2614447 
The closing date is 1 April 2009. 


Brentford TW8 9HH 


PRIZE WINNERS 

The solution of the January 2009 Hexadoku is: 4395C. 
The E-blocks Starter Kit Professional goes to: 
George Hardill (UK). 

An Elektor SHOP voucher worth £40.00 goes to: 
Jean-Louis Vidaud (France); Bernt Hörmann (Germany); 
Carsten Bohemann (Germany). 


Congratulations everybody! 
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Elbe-Weser marine pilot transceiver (ca. 1960) 


Jan Buiting 
(Elektor UK/US 
Editorial) 


Nothing, zilch, nada 
from Google on this 
bright yellow, port- 
able, NBFM 70 MHz 
receiver/transmit- 

ter from Philips duly 
labelled “Fabr. Nr. 
LO 601” and “Type 
ARR105-01”. It goes 
by two other names 
as well — having 
peeled off a sticker 
applied over another 
one on the side of the 
chassis, | was able to 
read ‘LO 777’ and 
‘ARR110-01’ in the 
respective boxes. For- 
tunately, the radio is 
not a total mystery. My 
archives indicate that 
it was used by pilots 
assisting with ship 
navigation around the 
light vessel ‘Elbe 1’ in 
the (huge) Elbe-Weser 
area in northwest Ger- 
many. In the early 
1960s the busy ship 
traffic in this area was 
controlled by a marine 
operational centre in 
Cuxhaven using a 100- 
m high mast and an 
advanced shore-base 
radar system supplied 
by Philips. 


The transceiver meas- 
ures 300x270x130 
mm and should weigh 
about 7 kg with its 
NiCd battery pack 
installed. The case is 
made from polyes- 
ter resin reinforced 
with glass fabric. It is 
claimed to be resist- 
ant to moisture, even 
sea water. The case is 
opened by turning four 
levers inside chrome- 
plated clamp rings on 
the sides. 


Greeted by the smell 
of pertinax and sol- 
der rosin so typical of 





1950s/60s radio gear, 
my immediate impres- 
sion is that although 
the equipment con- 
struction is tidy to 
paranoid levels, this 
is not a product from 
the Philips Telecom- 
munications Industry 
(PTI) factories in Hol- 
land. The clues are in 
the mixed brands of 
components used: an 
Ohmite power resis- 
tor, Eroid and Ero- 
foil capacitors, a Preh 
pot, Valvo semicon- 
ductors and a Holmco 
loudspeaker. None 
of these would have 
been used by PTI Hol- 
land in the 1960s — 
all components would 
be Philips’ own make. 
My best guess is that 
the LO 601 (or 777) 
was commissioned for 
production by Lorenz 
and then rebadged for 
Philips Germany. 


The next surprise is 
that the ceramic 7- 
pin valve sockets fit- 
ted on the chassis do 
not hold valves but 
serve as through con- 
nects to circuitry neatly 
packaged in modules! 
Inside the modules | 
found ‘pencil’ valves 
of the Philips DF/DL 
series. These are also 
known as ‘battery 
valves’ because they 
were designed for use 
in battery-operated 
MW/LW/FM radios. 
The letter ‘D’ indicates 
a directly heated cath- 
ode for 1.2-VDC oper- 
ation (yes, that’s five in 
series at 6 volts). 


The receiver is a crys- 
tal controlled double 
superheterodyne with 
unknown first and 
second IFs, employ- 
ing a 7.5435 MHz xtal 
oscillator for the sec- 
ond mixer. Only the 


RETRONICS 


AF section is transistorised with 
a few OC trannies. 


The transmitter is a conven- 
tional design too with crystals, 
frequency multiplier stages and 
a simple RF power amplifier 
— all with just four DF73 pen- 
cil valves. 

The +70 V and +150 V HT sup- 
ply is a conventional power mul- 
tivibrator using two OC 16s, two 
transformers and a selenium 
bridge rectifier — electronics’ 
foulest smelling part when it 
burns out! 

The controls on the radio have a 
‘feel’ no longer encountered on 
modern equipment. Tactile and 
audible feedback (‘clicks and 
springs’) reign supreme here and 
the general impression is one of 
extreme sturdiness and atten- 
tion to ergonomic detail. This is 
helped by precision engineered 
constructions like the channel 
selector knob that also acts as 
the on/off switch. The 10x75 mm 
hinged lid on the loudspeaker 
grille has a stud on it that drops 
into a matching opening in the 
channel knob when this is turned 
to the Off position. 

Remarkably the radio has a 
240 Q balanced cable connec- 
tion right beside to the expected 
(50 Q unbalanced) S0239 
socket, which takes a 4 wave 
whip antenna. 


Unfortunately the radio is missing 
its original PTT microphone and 
the battery charger cable. Still, 
the yellow box came alive with a 
characteristic inverter whine and 
a loud FM hiss when connected 
to a 6 volts, 2 amps power sup- 
ply. On channel C (71.7500 MHz 
simplex) | was able to measure 
750 mW of transmit power and 
about 1.5 pV receiver sensitivity 
(for 12 dB S/N). Enough to cover 
up to 10 kilometres out at sea. If 
you can help me find the serv- 
ice documentation or the micro- 
phone set for this early ‘hand- 
held’, please let me know. 
(080962-1) 


Retronics is a monthly column covering vintage electronics including legendary Elektor designs. Contributions, suggestions and requests are 


welcomed; please send an email to editor@elektor.com 
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WAITTUTISHOWCASE 


To book your showcase space contact Huson International Media 


LARIT T EO) eek y ey iii Fax 0044 (0) 1932 564998 


AVIT RESEARCH 


www.avitresearch.co.uk 

USB has never been so simple... 

with our USB to Microcontroller Interface cable. 
Appears just like a serial port to both PC and 


Microcontroller, for really easy USB connection to 
your projects, or replacement of existing RS232 


interfaces. 


Se, See our webpage for more 
w” details. From £10.00. 


BETA LAYOUT 

www.pcb-pool.com 

Beta layout Ltd Award- 

winning site in both 

English and German 

offers prototype 

PCBs at a fraction of the cost of the usual 
manufacturer’s prices. 


ByVac 
www.byvac.com 
e USB to I2C 

e Microcontrollers 
e Forth 

e Serial Devices 


C S TECHNOLOGY LTD 


www.cstech.co.uk 

Low cost PIC prototyping kits, PCB's and 
components, DTMF decoder kits, CTCSS, FFSK, 
GPS/GSM, radio equipment and manuals. 

PCB design and PIC program development. 


DECIBIT CO.,LTD. 
www.decibit.com 

e Development Kit 2.4 GHz 
e Transceiver nRF24L01 

e AVR MCU ATmega168 


elektor. 
com 
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DESIGNER SYSTEMS 


http://www.designersystems.co.uk 
Professional product development services. 
e Marine (Security, Tracking, Monitoring & control) 
e Automotive (AV, Tracking, 
Gadget, Monitoring & control) 
e Industrial (Safety systems, 
Monitoring over Ethernet) 
e Telecoms (PSTN handsets, GSM/GPRS) 
e AudioVisual ((HD)DVD accessories & controllers) 
Tel: +44 (0)1872 223306 


EASYDAQ 


www.easydaq.biz 
e USB powered, 4 relays + 4 DIO channels 
e Will switch 240VAC @ 10 amps « 

e Screw terminal access 

e LabVIEW, VB, VC 

e Free shipping 

e From £38 

Design & supply of USB, USB Wireless, 

Ethernet & Serial, DAQ, Relay & DIO card 
products. info@easydaq.biz 


Rasy DAD 


ee a a T 


EASYSYNC 


http://www.easysync.co.uk , 

EasySync Ltd sells a wide 

range of single and multi- 

port USB to RS232/R$422 

and RS485 converters at competitive prices. 


ELNEC 


www.elnec.com 
e device programmer 
manufacturer 
e selling through contracted 
distributors all over the world 
e universal and dedicated device programmers 
e excellent support and after sale support 
e free SW updates 
o reliable HW 
e once a months new SW release 
e three years warranty for most programmers 


FIRST TECHNOLOGY TRANSFER LTD. 

http://www. ftt.co.uk/PICProTrng.html 

Microchip Professional C 

and Assembly 

Programming Courses. 

The future is embedded. 

Microchip Consultant / Training Partner developed 

courses: 

e Distance learning / instructor led 

e Assembly / C-Programming of PIC16, PIC18, 
PIC24, dsPIC microcontrollers 

e Foundation / Intermediate 


First 


technolog 
Fronsfer Lid. 


FLEXIPANEL LTD 


www.flexipanel.com 

TEAclippers - the smallest 

PIC programmers in the world, 

from £20 each: 

e Per-copy firmware sales 

e Firmware programming & archiving 

e |n-the-field firmware updates 

e Protection from design theft by subcontractors 


FUTURE TECHNOLOGY DEVICES 
http://www.ftdichip.com 


FTDI designs and sells 

USB-UART and USB-FIFO 

interface i.c.’s. 

Complete with PC drivers, 

these devices simplify the task of designing or 
upgrading peripherals to USB 

LONDON ELECTRONICS COLLEGE 
Vocational training and education 

for national qualifications in 

Information Technology (BTEC First National, 
Higher National NVQs, GCSEs and GCEs). Also 


http://www.lec.org.uk E [ 
Electronics Engineering and JEL 
Technical Management and Languages. 


LCDMOD KIT 


http://www. Icdmodkit.com 
Worldwide On-line retailer 
e Electronics components 
e SMT chip components 

e USB interface LCD 

e Kits & Accessories 

e PC modding parts 

e LCD modules 


MQP ELECTRONICS 


www.mqgp.com 
e Low cost USB Bus Analysers 

e High, Full or Low speed captures 

e Graphical analysis and filtering 

e Automatic speed detection 

e Bus powered from high speed PC 

e Capture buttons and feature connector 
e Optional analysis classes 





elektor - 3/2009 


products and services directory 


www.elektor.com 


OBD2CABLES.COM 


http://www.obd2cables.com 

e Thousands of OBD cables and connectors in 
stock 

e Custom cable design and manufacturing 

e OBD breakout boxes and simulators 

e Guaranteed lowest prices 

e Single quantity orders OK 

e Convenient online ordering 

e Fast shipping 

Visit our website, or email us at: 

Sales@obd2cables.com 


ROBOT ELECTRONICS 


http://www.robot-electronics.co.uk 
Advanced Sensors and Electronics for Robotics 
e Ultrasonic Range Finders 

e Compass modules 

e Infra-Red Thermal sensors 

e Motor Controllers 

e Vision Systems 

e Wireless Telemetry Links 

e Embedded Controllers 


Elektor Electronics has a feature to help 
customers promote their business, 

Showcase - a permanent feature of the 
magazine where you will be able to showcase 
your products and services. 


ROBOTIQ 


http://www.robotig.co.uk 

Build your own Robot! 

Fun for the whole family! 

e MeccanoTM Compatible 

e Computer Control 

e Radio Control 

e Tank Treads 

e Hydraulics 

Internet Technical Bookshop, 

1-3 Fairlands House, North Street, Carshalton, 
Surrey SM5 2HW 

email: sales@robotiq.co.uk Tel: 020 8669 0769 


SCANTOOL.NET 


htto://www.scantool.net 
ScanTool.net offers a complete line 
of PC-based scan tools for under £50. 
e 1 year unconditional warranty 
e 90 day money back guarantee 
e For use with EOBD compliant vehicles 
e Fast shipping 
e Compatible with a wide range 
of diagnostic software 
Visit our website, or email us at: 
sales@scantool.net 


www.elektor.com 


SHOWCASE YOUR COMPANY HERE 


e For just £242 + VAT (£22 per issue for 
eleven issues) Elektor will publish your 
company name, website address and a 
30-word description 

e For £363 + VAT for the year (£33 per 
issue for eleven issues) we will publish 
the above plus run a 3cm deep full colour 


| I wish to promote my company, please book my space: 


e Text insertion only for £242 + VAT 


NAME sean sere nE A A RI N EAA 


e Text and photo for £363 + VAT 
PA AAT ORGANISATION: 


USB INSTRUMENTS 


http://www.usb-instruments.com 
USB Instruments specialises 

in PC based instrumentation 
products and software such 

as Oscilloscopes, Data 

Loggers, Logic Analaysers 

which interface to your PC via USB. 


VIRTINS TECHNOLOGY 
www.virtins.com 

PC and Pocket PC based 
virtual instrument such 

as sound card real time 
oscilloscope, spectrum 
analyzer, signal generator, 
multimeter, sound meter, 
distortion analyzer, LCR meter. 
Free to download and try. 


CANDO - CAN BUS ANALYSER 

http://www.cananalyser.co.uk 

e USB to CAN bus interface 

e USB powered . 

e FREE CAN bus analyser S/W 

e Receive, transmit & log. 
CAN messages 

e [5011898 & CAN 
2.0a/2.0b compliant {h )=ironics 


e Rugged IP67 version available 





image - e.g. a product shot, a screen shot 
from your site, a company logo - your 
choice 


Places are limited and spaces will go on 
a strictly first come, first served basis. 


So-please fax back your order today! 


JIB EE aces ctene et ecw tse A E E E A A EEE RE 
ADDRES a E E E T E E E E resaeeeeeecneicnete 


PLEASE COMPLETE COUPON BELOW AND FAX BACK TO 00-44-(0)1932 564998 
ONEAN NANE A E E E A EE N T E TTE EA I A E E EE A A 
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BOOKS, CD-ROMs, DVDs, KITS & MODULES 


Going Strong 


A world of electronics es 
from f single shop! Microcontroller 


Systems Engineering 


This book covers 45 exciting and fun pro- 
jects for PIC, AVR and ARM microcontrol- 


lers. Each project has a clear description 











of both hardware and software with pic- 
tures and diagrams, which explain not just 
how things are done but also why. As you 
go along the projects increase in difficulty 
and the new concepts are explained. You 
can use it as a projects book, and build the 
projects for your own use. Or you can use 


it as a study guide. 


336 pages ° ISBN 978-0-905705-75-0 
£29.00 ° US $58.00 


Pic Microcontrollers 





Silent alarm, poetry box, night buzzer and more 


PIC Microcontrollers 


Connect your mouse into new embedded applications This hands-on book covers a series of 


Mouse Interfacing with USB and PS/2 exciting and fun projects with PIC micro- 


controllers. You can built more than 50 
The mouse is one of the best proven, widely used and inexpensive man-machine interfaces ever projects for your own use. The clear expla- 
devised, yet its presence in the world of embedded systems is still a rarity. Indeed, there are few nations, schematics, and pictures of each 
embedded engineers today having practical experience of how to implement the hardware and project on a breadboard make this a fun 
software required to ‘enable’ mouse input. In Mouse Interfacing with USB and PS/2, the concepts activity. The technical background infor- 
needed are thoroughly explained. This book describes in-depth how to connect the mouse into mation in each project explains why the 
new embedded applications. It details the two main interface methods, PS/2 and USB, and offers project is set up the way it is, including the 
applications guidance with hardware and software examples plus tips on interfacing the mouse use of datasheets. Even after you've built 
to typical microcontrollers. A wide range of topics is explored, including ballistic profiles for fast- all the projects it will still be a valuable 


yet-precise response, USB descriptors, a four-channel, millivolt-precision voltage reference and reference guide to keep next to your PC. 


a variety of examples all with fully documented source-code. 


446 pages ° ISBN 978-0-905705-70-5 
256 pages ° ISBN 978-0-905705-74-3 ° £26.50 ° US $53.00 £27.95 ° US $55.90 





Prices and item descriptions subject to change. E. & O.E 
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E iest 


From LED to graphical LCD 


Universal Display Book 
for PIC Microcontrollers 


This book begins with simple programs to 
flash LEDs, and eventually by stages to use 
other display indicators such as the 7-seg- 
ment and alphanumeric liquid crystal dis- 
plays. As the reader progresses through the 
book, bigger and upgraded PIC chips are 
introduced, with full circuit diagrams and 
source code, both in assembler and C. A 
tutorial is included using the MPLAB program- 
ming environment, together with the PCB 
design package and EAGLE schematic to 


enable readers to create their own designs. 


192 pages ° ISBN 978-0-905705-73-6 
£23.00 ° US $46.00 






be 
Principles and Practice 


Computer Vision 


Computer vision is probably the most 





exciting branch of image processing, and 
the number of applications in robotics, 
automation technology and quality control 
is constantly increasing. Unfortunately 
entering this research area is, as yet, not 
simple. Those who are interested must first 
go through a lot of books, publications 
and software libraries. With this book, 
however, the first step is easy. The theore- 
tically founded content is understandable 


and is supplemented by many examples. 


320 pages ° ISBN 978-0-905705-71-2 
£32.00 ° US $64.00 
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A DIY system made from recycled components 


Design your own 


Embedded Linux 
control centre on a PC 


This book covers a do-it-your-self system 
made from recycled components. The 
main system described in this book re- 
uses an old PC, a wireless mains outlet 
with three switches and one controller, 
and a USB webcam. All this is linked to- 
gether by Linux. This book will serve up 
the basics of setting up a Linux environ- 
ment — including a software develop- 
ment environment — so it can be used as 
a control centre. The book will also guide 
you through the necessary setup and 
configuration of a webserver, which will 
be the interface to your very own home 
control centre. All software needed will 
be available for downloading from the 


Elektor website. 


234 pages ° ISBN 978-0-905705-72-9 
£24.00 ° US $48.00 


More information on the 
Elektor Website: 


www.elektor.com 


Elektor 

Regus Brentford 

1000 Great West Road 
Brentford 

TW8 9HH 

United Kingdom 

Tel.: +44 20 8261 4509 
Fax: +44 20 8261 4447 


Email: sales@elektor.com 
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110 issues, more than 2,100 articles 


DVD Elektor 1990 
through 1999 


This DVD-ROM contains the full range of 
1990-1999 volumes (all 110 issues) of 
Elektor Electronics magazine (PDF). The 
more than 2,100 separate articles have 
been classified chronologically by their 
dates of publication (month/year), but 
are also listed alphabetically by topic. A 
comprehensive index enables you to 
search the entire DVD. The DVD also con- 
tains (free of charge) the entire ‘The Ele- 
ktor Datasheet Collection 1...5’ CD-ROM 
series, with the original full datasheets of 
semiconductors, memory ICs, microcon- 


trollers, and much more. 


ISBN 978-0-905705-76-7 ° £69.00 ° US $109.00 


Modern technology for everyone 


FPGA Course 


FPGAs have established a firm position in 
the modern electronics designer’s toolkit. 
Until recently, these ‘super components’ 
were practically reserved for specialists in 
high-tech companies. The nine lessons 
on this courseware CD-ROM are a step 
by step guide to the world of Field Pro- 
grammable Gate Array technology. Sub- 
jects covered include not just digital logic 
and bus systems but also building an 
FPGA webserver, a 4-channel multimeter 
and a USB controller. The CD also con- 
tains PCB layout files in pdf format, a 
Quartus manual, project software and 


various supplementary instructions. 


ISBN 978-90-5381-225-9 © £14.50 ° US $29.00 
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Prices and item descriptions subject to change. E. & O.E 
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All articles published in 2008 


DVD Elektor 2008 


This DVD-ROM contains all editorial arti- 
cles published in Volume 2008 of the 
English, Spanish, Dutch, French and Ger- 
man editions of Elektor magazine. Using 
Adobe Reader, articles are presented in 
the same layout as originally found in 
the magazine. The DVD is packed with 
features including a powerful search en- 
gine and the possibility to edit PCB layouts 
with a graphics program, or printing hard 


copy at printer resolution. 


ISBN 978-90-5381-235-8 ° £17.50 ° US $35.00 
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More than 68,000 components 


ECD 4 


The program package consists of eight 
databanks covering ICs, germanium and 
silicon transistors, FETs, diodes, thyristors, 
triacs and optocouplers. A further eleven 
applications cover the calculation of, 
for example, LED series droppers, zener 
diode series resistors, voltage regulators 
and AMVs. A colour band decoder is in- 
cluded for determining resistor and in- 
ductor values. ECD 4 gives instant access 
to data on more than 68,000 compo- 
nents. All databank applications are fully 
interactive, allowing the user to add, edit 
and complete component data. This CD- 
ROM is a must-have for all electronics 


enthusiasts. 


ISBN 978-90-5381-159-7 ° £17.50 ° USS 35.00 


BOOKS, CD-ROMs, DVDs, KITS & MODULES 





CapSense Buttons 


Evaluation Kit 
(January 2009) 


This kit is for learning about touch sens- 
ing buttons. The PSoC device used on the 
evaluation board has up to 10 I/Os for 
buttons, LEDs and general-purpose I/O 
devices. The kit contains the CY3218- 
CAPEXP1 evaluation board, a retractable 
USB mini cable (A to mini B), a PSoC 
CY3240-I2 bridge board and an AA bat- 
tery. Also included is the kit CD which 
contains PsOC programmer, .NET 
Framework 2.0, PSoC Express 3, 
CapSense Express Extension Pack and 


the CapSense Express documentation. 


Art-Nr. 080875-1 ° £27.50 ° US $39.95 





with Special Effects 


(December 2008) 


If you fit a line of LEDs on a circular PCB 
and power them on continuously, they 
generate rings of light when the board is 
spun. If you add a microcontroller, you 
can use the same set of LEDs to obtain a 
more interesting effect by generating a 
‘virtual’ text display. The article also de- 
scribes a simple technique for using the 
Earth's magnetic field to generate a syn- 
chronisation pulse. The potential appli- 
cations extend from rotation counters to 


an electronic compass. 


Kit of parts incl. SMD-stuffed PCB and 
programmed controller 


Art-Nr. 080678-71 ° £39.00 © US $59.00 


Remote control 
by Mobile Phone 


(November 2008) 


Remote control using mobile phones and 
SMS (Text Messaging) is in great demand 
but many systems on sale suffer from im- 
perfections. This ingenious new design 
combines powerful capabilities with low 
technical overheads. It has programma- 
ble AC mains switching outlets plus status 
reports by text message and alarm-acti- 
vated delivery of GPS data. Remote con- 
trol by mobile was never easier, cheaper 


or more reliable! 


Kit of parts, incl. PCB, programmed 
controller and all parts 


Art. # 080324-71 ° £54.00 ° US $99.00 





Elektor SMT Reflow Oven 


(October 2008) 


The Elektor SMT reflow oven will faithfully 
handle most if not all your soldering of 
projects using surface mount devices 
(SMDs). The oven is particularly suited for 
use not just in Colleges, workshops, clubs 
and R&D laboratories, but also by the ad- 
vanced electronics enthusiast. This pre- 
cious workbench tool is at home where 
SMD boards have to be produced to a 
variety of requirements on size, compo- 


nents and soldering materials. 


Size:418x372x250 mm 
(16.5x 14.6x 10 inch) 


Art. # 080663-91 ° £962.00 (Excl. VAT) ° 
US $1665.00 (Excl. VAT) 
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March 2009 (No. 387) £ USS 


M16C TinyBrick 
080719-91 .... Kit of parts: TinyBrick-PCB with SMD parts and 

microntroller premounted; plus all other parts................ 54.00........87.50 
February 2009 (No. 386) 
Model Coach Lighting Decoder 
080689-1 ......PCB, long (1 = 230 mm)... esccccssssssesscscssssssssessscssssssseeees 7.30........10.95 
080689-2 ...... PCB, medium (| = 190mm) .000........cecccccssssssssessccssssssseeeees 7.30........10.95 
080689-3......PCB, short (| = 110mm)... escccccsssecssssssssssseescsssssssseseees 5.80.......... 8.95 
080689-41 .... PICT 2F683, programmed...............ssscccsssssscsssseecssssseessssseees O20 veces. 9.50 
Transistor Curve Tracer 
080068-1- Mam PER. minean EEE 26.50........42.00 
080068-91 .... PCB, populated and tested ...........cesscsssssssessssseesssseesssseees 55.00........82.50 
January 2009 (No. 385) 
Radio for Microcontrollers 
071125-71 ....868 MHZ module ciiisean TA 9.95 
ATM18 on the Air 
071125-71 ....868 MHz module ............ssecccssssssccssssescssssseccsssssesesssseessssseess FDU teres 9.95 
Meeting Cost Timer 
080396-41 ....ATmegal68, programmed .....0.....c..ccseecssseesssseesssseeesssseeen 8.50........12.50 
Capacitive Sensing and the Water Cooler 
080875-91 .... Touch Sensing Buttons Evaluation kit ..............c...ssescsssees 27.50........39.95 
080875-92 .... Touch Sensing Slider Evaluation Kit... 27.50........39.95 
Three-Dimensional Light Source 
080355-1...... Printed circuit board ..........ssssssscssssescssssseccsssseecssssseeesssses 24.90........39.90 
Moving up to 32 Bit 
080632-91 .... ECRM40 module ..........sesccssssscsssssseccssssessssssecssssssessesssees 32.00........46.50 
December 2008 (No. 384) 
PLDM 
071129-1...... Printed circuit board ............sssssccssssescsssssescssssecssssseessssssess 5.80.......... 9.50 
Hi-fi Wireless Headset 
080647-1 ...... Printed circuit board: Transmitter..............c...ssssssesesssseees 7.90........15.80 
080647-2 ...... Printed circuit board: REC@iVEr..............ssssccsssssescsssssessessseees 7.90........15.80 


LED Top with Special Effects 
080678-71 .... Kit of parts incl. SMD-stuffed PCB 


and programmed controller ............cc..scsssesssecssssesssseeeeeee 39.00........59.00 
November 2008 (No. 383) 
Motorised Volume Pot 
071135-41 .... Programmed controller ATMEGA8-16PU ......0.......sccc.ssseee 5.90........11.80 
Speed Camera Warning Device 
080615-1...... Printed circuit board uu... ...ssssssscsssesccsssseeccsssseecesssseessssses 15.50........31.00 
080615-41 .... Programmed controller PIC] 6F876A-I/SO.............0....000.. 11.80........23.60 
Remote Control by Mobile Phone 
080324-1...... Printed circuit board ...........ssssssscssssscssssseccsssseecssssseeeessses 17.80........35.60 
080324-41 .... Programmed controller ATMEGA8-16PU ..............00....0. 5.90........ 11.80 
8032457 Ms Kito DONS asses tee cee creed Rca ee ees 54.00........99.00 
Tracking Hot Spots 
080358-1...... Printed circuit board ............sssesssssssescssssseccsssseesessssecesssssess 9.10........18.20 
ATmega meets Vinculum 
071152-91) VDIP] module nee eee ee alee ae. 22.50........45.00 
October 2008 (No. 382) 
Communicating with CAN 
071120-71 ....PCB, partly populated ......0.....cecccssssssssssssssessssssesssseeesssees 54.90......109.80 
Elektor SMT Precision Reflow Oven 
080663-91 .... Ready to use oven (230VAC only) ......e.ssssssssssssecccsssssssees 962.00....1665.00 
Multi-purpose GPS Receiver 
070309-41 .... Programmed controller PIC] 8F2520.............sssscssssseccesseee 11.60........23.20 
ATM18 Relay Board and Port Expander 
071035-72 .... Relay PCB with all components and relays..................s00. 36.90........73.80 
071035-95 .... Port Extension PCB, populated with SMD ....................0 13.40........26.80 
RF Sweep Frequency Generator / Spectrum Analyser 
040360-41 .... Programmed controller ATmega8535............c:.ssessssee 21.80........43.60 


3/2009 - elektor 





Microcontroller Systems Engineering 
ISBN 978-0-905705-75-0 sssnse £29.00.....US $58.00 


PIC Microcontrollers 
ISBN 978-0-905705=70-5............00. £27.95.....US $55.90 


Computer Vision 
ISBN 978-0-905705-71-2 .........sse000 £32.00.....US $64.00 


pi | i 


ektor 1990 through 
FPGA Course 


ISBN 978-90-5381-225-9...........0000 £14.50.....US $29.00 


Ethernet Toolbox 
ISBN 978-90-538 1-21 4-3 ...........0000 £19.50.....US $39.00 
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LED Top with Special Effects 


Art. # 080678-71 £39.00.... US $59.00 


Evaluation Kit CapSense Sliders 
Art. # 080875-92 £27.50.....US $39.95 


Kits & Modules 


Remote control by Mobile Phone 
Art. # 080324-71 £54.00.... US $99.00 


Order quickly and securely through 
www.elektorcom/shop 
or use the Order Form near the end 








of the magazine! 
Elektor 
Regus Brentford 
1000 Great West Road 
S a O p Brentford TW8 9HH ° United Kingdom 


Tel. +44 20 8261 4509 
Fax +44 20 8261 4447 
Email: sales@elektor.com 
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LOSE) COMING ATTRACTIONS 


NEXT MONTH IN ELEKTOR 


Test bench for model engines 


High speed combustion engines for model airplanes, helicopters and so on require running in before they can be built 
into the model with confidence. Running in is a bothersome process if carried our manually. So, a test bench was de- 
signed that handles the process automatically. A servo is used to operate the throttle valve and the engine is automati- 
cally cycled through short periods of high and low speed, with constant rev counting and temperature monitoring. All 
measurement data can be sent to a PC for displaying and analysis. 





SPICE simulation for LEDs 


Hysteretic high-brightness LED drivers offer simple and low-cost implementations that require a minimum of exter- 
nal components. The complete circuit forms a self-oscillating system that is often not clearly understood by circuit 
designers. Consequently, they have trouble defining the right component values in the circuit. In this article we 
explain methods of LED driver design using simulation models in SPICE. 








C Display 


Our May 2008 issue featured a very straightforward graphical control and measurement device using the compact 
M16C Display Board and its built-in BASIC interpreter. Readers who prefer programming in C can also use the de- 
sign if they build this mini circuit and download some free software from the web. 





Article titles and magazine contents subject to change, please check ‘Magazine’ on www.elektor.com The April 2009 issue comes on sale on Thursday 19 March 2009 (UK distribution only). 
UK mainland subscribers will receive the issue between 14 and 17 March 2009. 


Elektor on the web 


All magazine articles back to volume 2000 are available online in pdf format. The article summary and parts list (if applicable) can 
be instantly viewed to help you positively identify an article. Article related items are also shown, including software downloads, circuit 
boards, programmed ICs and corrections and updates if applicable. Complete magazine issues may also be downloaded. 

yprass CyFi™ Low-Power RF 


nies worldwide i = 4 Simple. Reliable. Power Efficient. 


News Pagarini Shop Subscribe mow 


In the Elektor Shop you'll find all other products sold by the e Eker 
publishers, like CD-ROMs, kits and books. A powerful search warm 


function allows you to search for items and references across 
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Fish-shaped LED fixtures 


the entire website. 
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Also on the Elektor website: 
e Electronics news and Elektor announcements 
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e Readers Forum 
e PCB, software and e-magazine downloads 






è Surveys and polls 
e FAQ, Author Guidelines and Contact 
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Description Price each Qty. Total Order Code 


METHOD OF PAYMENT 
(see reverse before ticking as appropriate) 


Mouse Interfacing £26.50 
Microcontroller Systems Engineering NEW! 


C] Bank transfer 


C] Cheque 
(UK-resident customers ONLY) 


C] Giro transfer 


DVD Elektor 2008 
DVD Elektor 1990 through 1999 


N 
CapSense Buttons Kit (080875-91) £27.50 EE 


CapSense Sliders Kit (080875-92) £27.50) | 
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ORDERING INSTRUCTIONS, P&P CHARGES 





All orders, except for subscriptions (for which see below), must be sent BY POST or FAX to our Brentford address using the Order Form overleaf. 
Online ordering: www.elektor.com/shop 

Readers in the USA and Canada should send orders, except for subscriptions (for which see below), to the USA address given on the order 
form. Please apply to Elektor US for applicable P&P charges. Please allow 4-6 weeks for delivery. 

Orders placed on our Brentford office must include P&P charges (Priority or Standard) as follows: Europe: £6.00 (Standard) or £7.00 
(Priority) Outside Europe: £9.00 (Standard) or £11.00 (Priority) 
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All orders must be accompanied by the full payment, including postage and packing charges as stated above or advised by Customer Services staff. 
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BIC: ABNAGB2L. Currency: sterling (UKP). Please ensure your full name and address gets communicated to us. 

Cheque sent by post, made payable to Elektor Electronics. We can only accept sterling cheques and bank drafts from UK-resident customers or 
Subscribers. We regret that no cheques can be accepted from customers or subscribers in any other country. 

Giro transfer into account no. 34-152-3801, held by Elektor Electronics. Please do not send giro transfer/deposit forms directly to us, but instead 
use the National Giro postage paid envelope and send it to your National Giro Centre. 

Credit card VISA and MasterCard can be processed by mail, email, web, fax and telephone. Online ordering through our website is 

SSL-protected for your security. 


COMPONENTS 





Components for projects appearing in Elektor are usually available from certain advertisers in this magazine. If difficulties in the supply 
of components are envisaged, a source will normally be advised in the article. Note, however, that the source(s) given is (are) not exclusive. 
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Delivery Although every effort will be made to dispatch your order within 2-3 weeks from receipt of your instructions, we can not guarantee this 
time scale for all orders. Returns Faulty goods or goods sent in error may be returned for replacement or refund, but not before obtaining our 
consent. All goods returned should be packed securely in a padded bag or box, enclosing a covering letter stating the dispatch note number. 
If the goods are returned because of a mistake on our part, we will refund the return postage. Damaged goods Claims for damaged goods 
must be received at our Brentford office within 10-days (UK); 14-days (Europe) or 21-days (all other countries). Cancelled orders All cancelled 
orders will be subject to a 10% handling charge with a minimum charge of £5.00. Patents Patent protection may exist in respect of circuits, 
devices, components, and so on, described in our books and magazines. Elektor does not accept responsibility or liability for failing to identify 
such patent or other protection. Copyright All drawings, photographs, articles, printed circuit boards, programmed integrated circuits, diskettes 
and software carriers published in our books and magazines (other than in third-party advertisements) are copyright and may not be reproduced 
or transmitted in any form or by any means, including photocopying and recording, in whole or in part, without the prior permission of Elektor 
in writing. Such written permission must also be obtained before any part of these publications is stored in a retrieval system of any nature. 
Notwithstanding the above, printed-circuit boards may be produced for private and personal use without prior permission. Limitation of liability 
Elektor shall not be liable in contract, tort, or otherwise, for any loss or damage suffered by the purchaser whatsoever or howsoever arising out of, or in 
connexion with, the supply of goods or services by Elektor other than to supply goods as described or, at the option of Elektor, to refund the purchaser 
any money paid in respect of the goods. Law Any question relating to the supply of goods and services by Elektor shall be determined in all respects 
by the laws of England. 
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SUBSCRIPTION RATES FOR ANNUAL SUBSCRIPTION CONDITIONS 
SUBSCRIPTION The standard subscription order period is twelve months. If a 

Standard Plus permanent change of address during the subscription period means 
United Kingdom £44.00 £53.00 that copies have to be despatched by a more expensive service, 
ee ae no extra charge will be made. Conversely, no refund will be made, 
Surface Mail nor expiry date extended, if a change of address allows the use of 
Rest of the World £58.00 £67.00 a cheaper service. 


Student applications, which qualify for a 20% (twenty per cent) 
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reduction in current rates, must be supported by evidence of stu- 
Rest of the World £74.00 £83.00 dentship signed by the head of the college, school or university 
USA £99.95 ECM A: faculty. 
Canada €70.95 for special offers A standard Student Subscription costs £35.00, a Student 


Subscription-Plus costs £44.20 (UK only). 

Please note that new subscriptions take about four weeks from 
HOW TO PAY receipt of order to become effective. 

Cancelled subscriptions will be subject to a charge of 25% 
(twenty-five per cent) of the full subscription price or £7.50, 
whichever is the higher, plus the cost of any issues already 
dispatched. Subsciptions cannot be cancelled after they have 
run for six months or more. 
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BIC: ABNAGB2L. Currency: sterling (UKP). Please ensure your full name 
and address gets communicated to us. 

Cheque sent by post, made payable to Elektor Electronics. We can only 
accept sterling cheques and bank drafts from UK-resident customers or 
subscribers. We regret that no cheques can be accepted from customers 
or subscribers in any other country. 

Giro transfer into account no. 34-152-3801, held by Elektor Electronics. 
Please do not send giro transfer/deposit forms directly to us, but instead 
use the National Giro postage paid envelope and send it to your National 
Giro Centre. 

Credit card VISA and MasterCard can be processed by mail, email, 
web, fax and telephone. Online ordering through our website is SSL- 
protected for your security. January 2009 





DVD 


All articles in Elektor Volume.2008 


= 7 an 


This DVD-ROM contains all editorial articles published in 

Volume 2008 of the English, Spanish, Dutch, French and German 

editions of Elektor magazine. Using Adobe Reader, articles are 

presented in the same layout as originally found in the magazine. ISBN 978-90-5381-235-8 © £17.50 © US $35.00 
The DVD is packed with features including a powerful search 

engine and the possibility to edit PCB layouts with a graphics Elektor 
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program, or printing hard copy at printer resolution. 1000 Greai Weet Road 
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Powerful EDA Software at Affordable Prices 


= Easy to use, standard Windows interface. =» Automatic component placement 


= Publication quality schematics. and gateswap optimization. 
= Fully configurable bill of materials. = Highly configurable design rules. 
= Large component libraries for both » Interactive design rule checking. 
simulation and PCB layout. = Polygonal and split power planes. 
» Mixed mode SPICE circuit simulation. = World class shape based autorouter. 
= Co-simulation of PIC, AVR, 8051 and = Automatic mitre/unmitre commands. 
ARM7 microcontroller firmware. » Industry standard CADCAM & ODB++ output. 








= Integrates with MP-LAB and AVR Studio. «= Integrated 3D Viewer with 3DS and DXF export. 


All levels of the Proteus Design Suite now include a world class fully integrated shape based 
autorouter at no additional cost - prices start from just £150 exc. VAT & delivery 






wawlabcenter.com Visit our website or 
Electronic phone 01756 753440 


Labcenter Electronics Ltd. 53-55 “Main Street, Grassington, North Yorks. BD23 5AA. f ii t ij 
Registered in England 4692454 Tel: +44 (0)1756 753440, Email: info@labcenter.com OF MOre Getalls 








